-
Notifications
You must be signed in to change notification settings - Fork 30k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Consolidate publishing builds to Azure #117891
Comments
As part of this work, we should also improve the error message in case a build already exists. There have been multiple cases over the last several months in which a stable/insiders build fails due to the fact that a build for the commit in question has already been published. |
So I ran into a bit of a roadblock with this one... the current createAsset.ts takes in quite a few parameters that are really quite specific to where they were run... for example in linux:
while in macOS:
while in Windows:
The
and then the actual file inside the artifact (for example: "vscode-server-win32-arm64.zip") would be the file name. Is that... a good thing? I'm not so sure. Maybe it's fine. This task is stretching what Azure Pipelines was made to do... the logic would basically be: $set = [System.Collections.Generic.HashSet[string]]::new()
$currentCount = 0
while ($NUMBER_OF_EXPECTED_ARTIFACTS -gt $currentCount) {
try {
# Query the API for the artifacts for the current build
$res = Invoke-RestMethod "https://dev.azure.com/monacotools/Monaco/_apis/build/builds/$(Build.BuildId)/artifacts?api-version=6.0" -Headers @{
Authorization = "Bearer $env:SYSTEM_ACCESSTOKEN"
} -RetryIntervalSec 5 -MaximumRetryCount 5
} catch {
Write-Warning $_
$res = $null
}
if ($res -and $res.count) {
$currentCount = $res.count
$res.value | ForEach-Object {
$name = $_.name
if($name -match 'vscode-*' -and $set.Add($name)) {
# Download the artifact as a zip
Invoke-RestMethod $_.resource.downloadUrl -OutFile "$(Agent.TempDirectory)/$name.zip"
# Get parameters from artifact name
$vscode, $clientOrServer, $platform, $type = $name.Split('-')
# Get file name
Expand-Archive "$(Agent.TempDirectory)/$name.zip" -DestinationPath "$(Agent.TempDirectory)/$name"
$fileName = Get-ChildItem "$(Agent.TempDirectory)/$name"
$env:VSCODE_MIXIN_PASSWORD = "$(github-distro-mixin-password)"
$env:AZURE_DOCUMENTDB_MASTERKEY = "$(builds-docdb-key-readwrite)"
$env:AZURE_STORAGE_ACCESS_KEY = "$(ticino-storage-key)"
$env:AZURE_STORAGE_ACCESS_KEY_2 = "$(vscode-storage-key)"
node build/azure-pipelines/common/createAsset.js `
$clientOrServer `
$platform `
$type `
$fileName.Name `
$fileName.FullName
}
}
}
# wait 10s before polling again
Start-Sleep -Seconds 10
} The unfortunate part is that this would:
We could still go this route, as it would allow us to move off of storedprocs and only the Release stage will be running these JS files, but ... I do wonder if the extra complexity is worth it. |
Yeah I was thinking we could do just that. Either encode the info in the asset filename, or include some data (eg JSON) along with the actual file inside the artifact zip, which would tell
This is OK, we have a PS champ in the team now. 🏆
You actually made it look concise and readable, I really like it.
I think it's equivalent to today's "each call to createAsset.js needs to use the correct name otherwise things to sidewise"
Right, this is the interesting part. Also how do we make it work when reruning failed jobs? Maybe we can have it poll for how many jobs are still running? When that reaches 1 (the current) then we assume there's nothing else to do.
I really like the fact that (1) all publishing logic happens in one place, (2) every build output is forced to exist as a TFS asset, (3) publishing can be parallelized with other tasks and (4) we can potentially include in here other publishing tasks like Mooncake. The extra complexity is fine to have, as long as we keep it well oiled. On the actual script, I would actually make |
Until very recently, each build job was directly publishing builds to Azure Storage and CosmosDB. Recently, we made build jobs publish builds as build artifacts, such that it's straightforward for further jobs to download them and use them (ie test build jobs).
We could further:
cc @lszomoru
The text was updated successfully, but these errors were encountered: