steps: - task: NodeTool@0 inputs: versionSpec: "16.x" - task: geeklearningio.gl-vsts-tasks-yarn.yarn-installer-task.YarnInstaller@3 inputs: versionSpec: "1.x" - task: AzureKeyVault@1 displayName: 'Azure Key Vault: Get Secrets' inputs: azureSubscription: 'ClientToolsInfra_670062 (88d5392f-a34f-4769-b405-f597fc533613)' KeyVaultName: ado-secrets - script: | set -e cat << EOF > ~/.netrc machine github.com login azuredatastudio password $(github-distro-mixin-password) EOF git config user.email "sqltools@service.microsoft.com" git config user.name "AzureDataStudio" displayName: Prepare tooling - script: | set -e git remote add distro "https://github.com/$(VSCODE_MIXIN_REPO).git" git fetch distro git merge $(node -p "require('./package.json').distro") displayName: Merge distro - script: | mkdir -p .build node build/azure-pipelines/common/sql-computeNodeModulesCacheKey.js > .build/yarnlockhash displayName: Prepare yarn cache key - task: Cache@2 inputs: key: 'nodeModules | $(Agent.OS) | .build/yarnlockhash' path: .build/node_modules_cache cacheHitVar: NODE_MODULES_RESTORED displayName: Restore Cache - Node Modules continueOnError: true - script: | set -e tar -xzf .build/node_modules_cache/cache.tgz condition: and(succeeded(), eq(variables.NODE_MODULES_RESTORED, 'true')) displayName: Extract node_modules archive - script: | set -e CHILD_CONCURRENCY=1 yarn --frozen-lockfile displayName: Install dependencies condition: and(succeeded(), ne(variables['NODE_MODULES_RESTORED'], 'true')) - script: | set -e node build/azure-pipelines/common/listNodeModules.js .build/node_modules_list.txt mkdir -p .build/node_modules_cache tar -czf .build/node_modules_cache/cache.tgz --files-from .build/node_modules_list.txt condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true')) displayName: Create node_modules archive - script: | set -e yarn postinstall displayName: Run postinstall scripts condition: and(succeeded(), eq(variables['NODE_MODULES_RESTORED'], 'true')) # Mixin must run before optimize, because the CSS loader will # inline small SVGs - script: | set -e node build/azure-pipelines/mixin displayName: Mix in quality - script: | set -e yarn sqllint yarn extensions-lint yarn gulp hygiene yarn valid-layers-check displayName: Run hygiene, eslint condition: and(succeeded(), eq(variables['VSCODE_STEP_ON_IT'], 'false')) - script: | set -e yarn gulp compile-build yarn gulp compile-extensions-build yarn gulp minify-vscode yarn gulp vscode-linux-x64-min-ci yarn gulp vscode-web-min-ci yarn gulp vscode-reh-linux-x64-min yarn gulp vscode-reh-web-linux-x64-yarnrc-extensions yarn gulp vscode-reh-web-linux-x64-min displayName: Compile - script: | set -e yarn gulp compile-extensions displayName: Compile Extensions # disable smoke tests (karlb 3/2/2022) # # Per https://developercommunity.visualstudio.com/t/variablesexpressions-dont-work-with-continueonerro/1187733 we can't use variables # # in continueOnError directly so instead make two copies of the task and only run one or the other based on the SMOKE_FAIL_ON_ERROR value # - script: | # set -e # node ./node_modules/playwright/install.js # APP_ROOT=$(Agent.BuildDirectory)/vscode-reh-web-linux-x64 # xvfb-run yarn smoketest --build "$(Agent.BuildDirectory)/vscode-reh-web-linux-x64" --web --headless --screenshots "$(Build.ArtifactStagingDirectory)/smokeshots" --log "$(Build.ArtifactStagingDirectory)/logs/web/smoke.log" # displayName: Run smoke tests (Browser) (Continue on Error) # continueOnError: true # condition: and(succeeded(), and(eq(variables['RUN_TESTS'], 'true'), ne(variables['SMOKE_FAIL_ON_ERROR'], 'true'))) # disable smoke tests (karlb 3/2/2022) # - script: | # set -e # node ./node_modules/playwright/install.js # APP_ROOT=$(Agent.BuildDirectory)/vscode-reh-web-linux-x64 # xvfb-run yarn smoketest --build "$(Agent.BuildDirectory)/vscode-reh-web-linux-x64" --web --headless --screenshots "$(Build.ArtifactStagingDirectory)/smokeshots" --log "$(Build.ArtifactStagingDirectory)/logs/web/smoke.log" # displayName: Run smoke tests (Browser) (Fail on Error) # condition: and(succeeded(), and(eq(variables['RUN_TESTS'], 'true'), eq(variables['SMOKE_FAIL_ON_ERROR'], 'true'))) # - script: | # set -e # AZURE_STORAGE_ACCOUNT="$(sourcemap-storage-account)" \ # AZURE_STORAGE_ACCESS_KEY="$(sourcemap-storage-key)" \ # node build/azure-pipelines/upload-sourcemaps # displayName: Upload sourcemaps - script: | set -e VERSION=$(node -p "require(\"./package.json\").version") echo -e "{ \"version\": \"$VERSION\", \"quality\": \"$VSCODE_QUALITY\", \"commit\": \"$BUILD_SOURCEVERSION\" }" > ".build/version.json" node build/azure-pipelines/common/copyArtifacts.js displayName: Write Version Information - task: PublishBuildArtifacts@1 displayName: 'Publish Artifact: drop' - script: | set -e tar -czf $(Build.ArtifactStagingDirectory)/compilation.tar.gz .build out-* displayName: Compress compilation artifact - task: PublishPipelineArtifact@1 inputs: targetPath: $(Build.ArtifactStagingDirectory)/compilation.tar.gz artifactName: Compilation displayName: Publish compilation artifact - script: | set -e yarn gulp package-rebuild-extensions yarn gulp compile-extensions yarn gulp package-external-extensions displayName: Package External extensions - script: | set -e yarn gulp package-langpacks displayName: Package Langpacks - script: | set -e yarn gulp vscode-linux-x64-build-deb displayName: Build Deb - script: | set -e yarn gulp vscode-linux-x64-build-rpm displayName: Build Rpm - task: UseDotNet@2 displayName: 'Install .NET Core sdk for signing' inputs: packageType: sdk version: 5.0.x installationPath: $(Agent.ToolsDirectory)/dotnet - task: SFP.build-tasks.custom-build-task-1.EsrpCodeSigning@1 inputs: ConnectedServiceName: 'Code Signing' FolderPath: '$(Build.SourcesDirectory)/.build' Pattern: 'extensions/*.vsix,langpacks/*.vsix' signConfigType: inlineSignParams inlineOperation: | [ { "keyCode": "CP-233016", "operationSetCode": "OpcSign", "parameters": [ { "parameterName": "FileDigest", "parameterValue": "/fd \"SHA256\"" } ], "toolName": "sign", "toolVersion": "1.0" }, { "keyCode": "CP-233016", "operationSetCode": "OpcVerify", "parameters": [], "toolName": "sign", "toolVersion": "1.0" } ] SessionTimeout: 120 displayName: 'Signing Extensions and Langpacks' condition: and(succeeded(), eq(variables['signed'], true)) - script: | set -e ./build/azure-pipelines/web/createDrop.sh displayName: Create Drop - task: PublishBuildArtifacts@1 displayName: 'Publish Artifact: drop' continueOnError: true condition: succeededOrFailed() - task: ms.vss-governance-buildtask.governance-build-task-component-detection.ComponentGovernanceComponentDetection@0 displayName: 'Component Detection' inputs: failOnAlert: true