Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/build/azure-pipelines/product-compile.yml
3520 views
1
jobs:
2
- job: Compile
3
timeoutInMinutes: 60
4
pool:
5
name: AcesShared
6
os: macOS
7
templateContext:
8
outputs:
9
- output: pipelineArtifact
10
targetPath: $(Build.ArtifactStagingDirectory)/compilation.tar.gz
11
artifactName: Compilation
12
displayName: Publish compilation artifact
13
isProduction: false
14
sbomEnabled: false
15
steps:
16
- template: ./common/checkout.yml@self
17
18
- task: NodeTool@0
19
inputs:
20
versionSource: fromFile
21
versionFilePath: .nvmrc
22
23
- template: ./distro/download-distro.yml@self
24
25
- task: AzureKeyVault@2
26
displayName: "Azure Key Vault: Get Secrets"
27
inputs:
28
azureSubscription: vscode
29
KeyVaultName: vscode-build-secrets
30
SecretsFilter: "github-distro-mixin-password"
31
32
- script: node build/setup-npm-registry.js $NPM_REGISTRY
33
condition: and(succeeded(), ne(variables['NPM_REGISTRY'], 'none'))
34
displayName: Setup NPM Registry
35
36
- script: mkdir -p .build && node build/azure-pipelines/common/computeNodeModulesCacheKey.js compile $(node -p process.arch) > .build/packagelockhash
37
displayName: Prepare node_modules cache key
38
39
- task: Cache@2
40
inputs:
41
key: '"node_modules" | .build/packagelockhash'
42
path: .build/node_modules_cache
43
cacheHitVar: NODE_MODULES_RESTORED
44
displayName: Restore node_modules cache
45
46
- script: tar -xzf .build/node_modules_cache/cache.tgz
47
condition: and(succeeded(), eq(variables.NODE_MODULES_RESTORED, 'true'))
48
displayName: Extract node_modules cache
49
50
- script: |
51
set -e
52
# Set the private NPM registry to the global npmrc file
53
# so that authentication works for subfolders like build/, remote/, extensions/ etc
54
# which does not have their own .npmrc file
55
npm config set registry "$NPM_REGISTRY"
56
echo "##vso[task.setvariable variable=NPMRC_PATH]$(npm config get userconfig)"
57
condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true'), ne(variables['NPM_REGISTRY'], 'none'))
58
displayName: Setup NPM
59
60
- task: npmAuthenticate@0
61
inputs:
62
workingFile: $(NPMRC_PATH)
63
condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true'), ne(variables['NPM_REGISTRY'], 'none'))
64
displayName: Setup NPM Authentication
65
66
- script: |
67
set -e
68
69
for i in {1..5}; do # try 5 times
70
npm ci && break
71
if [ $i -eq 5 ]; then
72
echo "Npm install failed too many times" >&2
73
exit 1
74
fi
75
echo "Npm install failed $i, trying again..."
76
done
77
env:
78
ELECTRON_SKIP_BINARY_DOWNLOAD: 1
79
PLAYWRIGHT_SKIP_BROWSER_DOWNLOAD: 1
80
GITHUB_TOKEN: "$(github-distro-mixin-password)"
81
displayName: Install dependencies
82
condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true'))
83
84
- script: node build/azure-pipelines/distro/mixin-npm
85
condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true'))
86
displayName: Mixin distro node modules
87
88
- script: |
89
set -e
90
node build/azure-pipelines/common/listNodeModules.js .build/node_modules_list.txt
91
mkdir -p .build/node_modules_cache
92
tar -czf .build/node_modules_cache/cache.tgz --files-from .build/node_modules_list.txt
93
condition: and(succeeded(), ne(variables.NODE_MODULES_RESTORED, 'true'))
94
displayName: Create node_modules archive
95
96
- script: node build/azure-pipelines/distro/mixin-quality
97
displayName: Mixin distro quality
98
99
- template: common/install-builtin-extensions.yml@self
100
101
- script: npm exec -- npm-run-all -lp core-ci extensions-ci hygiene eslint valid-layers-check define-class-fields-check vscode-dts-compile-check tsec-compile-check
102
env:
103
GITHUB_TOKEN: "$(github-distro-mixin-password)"
104
displayName: Compile & Hygiene
105
106
- script: |
107
set -e
108
npm run compile
109
displayName: Compile smoke test suites (non-OSS)
110
workingDirectory: test/smoke
111
condition: and(succeeded(), eq(variables['VSCODE_STEP_ON_IT'], 'false'))
112
113
- script: |
114
set -e
115
npm run compile
116
displayName: Compile integration test suites (non-OSS)
117
workingDirectory: test/integration/browser
118
condition: and(succeeded(), eq(variables['VSCODE_STEP_ON_IT'], 'false'))
119
120
- task: AzureCLI@2
121
displayName: Fetch secrets
122
inputs:
123
azureSubscription: vscode
124
scriptType: pscore
125
scriptLocation: inlineScript
126
addSpnToEnvironment: true
127
inlineScript: |
128
Write-Host "##vso[task.setvariable variable=AZURE_TENANT_ID]$env:tenantId"
129
Write-Host "##vso[task.setvariable variable=AZURE_CLIENT_ID]$env:servicePrincipalId"
130
Write-Host "##vso[task.setvariable variable=AZURE_ID_TOKEN;issecret=true]$env:idToken"
131
132
- script: |
133
set -e
134
AZURE_STORAGE_ACCOUNT="vscodeweb" \
135
AZURE_TENANT_ID="$(AZURE_TENANT_ID)" \
136
AZURE_CLIENT_ID="$(AZURE_CLIENT_ID)" \
137
AZURE_ID_TOKEN="$(AZURE_ID_TOKEN)" \
138
node build/azure-pipelines/upload-sourcemaps
139
displayName: Upload sourcemaps to Azure
140
141
- script: ./build/azure-pipelines/common/extract-telemetry.sh
142
displayName: Generate lists of telemetry events
143
144
- script: tar -cz --exclude='.build/node_modules_cache' --exclude='.build/node_modules_list.txt' --exclude='.build/distro' -f $(Build.ArtifactStagingDirectory)/compilation.tar.gz $(ls -d .build out-* test/integration/browser/out test/smoke/out test/automation/out 2>/dev/null)
145
displayName: Compress compilation artifact
146
147
- script: npm run download-builtin-extensions-cg
148
env:
149
GITHUB_TOKEN: "$(github-distro-mixin-password)"
150
displayName: Download component details of built-in extensions
151
152
- task: ms.vss-governance-buildtask.governance-build-task-component-detection.ComponentGovernanceComponentDetection@0
153
displayName: "Component Detection"
154
inputs:
155
sourceScanPath: $(Build.SourcesDirectory)
156
alertWarningLevel: Medium
157
continueOnError: true
158
159