ci: use git-sdk-64-minimal build artifact
Instead of a shallow fetch followed by a sparse checkout, we are better off by using a separate, dedicated Pipeline that bundles the SDK as a build artifact, and then consuming that build artifact here. In fact, since this artifact will be used a lot, we spent substantial time on figuring out a minimal subset of the Git for Windows SDK, just enough to build and test Git. The result is a size reduction from around 1GB (compressed) to around 55MB (compressed). This also comes with the change where we now call `usr\bin\bash.exe` directly, as `git-cmd.exe` is not included in the minimal SDK. That reduces the time to initialize Git for Windows' SDK from anywhere between 2m30s-7m to a little over 1m. Note: in theory, we could also use the DownloadBuildArtifacts@0 task here. However, restricted permissions that are in effect when building from forks would let this fail for PR builds, defeating the whole purpose of the Azure Pipelines support for git.git. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
2e90484eb4
commit
6c1f4ae65a
@ -18,44 +18,18 @@ jobs:
|
|||||||
env:
|
env:
|
||||||
GITFILESHAREPWD: $(gitfileshare.pwd)
|
GITFILESHAREPWD: $(gitfileshare.pwd)
|
||||||
- powershell: |
|
- powershell: |
|
||||||
# Helper to check the error level of the latest command (exit with error when appropriate)
|
$urlbase = "https://dev.azure.com/git-for-windows/git/_apis/build/builds"
|
||||||
function c() { if (!$?) { exit(1) } }
|
$id = ((Invoke-WebRequest -UseBasicParsing "${urlbase}?definitions=22&statusFilter=completed&resultFilter=succeeded&`$top=1").content | ConvertFrom-JSON).value[0].id
|
||||||
|
$downloadUrl = ((Invoke-WebRequest -UseBasicParsing "${urlbase}/$id/artifacts").content | ConvertFrom-JSON).value[1].resource.downloadUrl
|
||||||
# Add build agent's MinGit to PATH
|
(New-Object Net.WebClient).DownloadFile($downloadUrl,"git-sdk-64-minimal.zip")
|
||||||
$env:PATH = $env:AGENT_HOMEDIRECTORY +"\externals\\git\cmd;" +$env:PATH
|
Expand-Archive git-sdk-64-minimal.zip -DestinationPath . -Force
|
||||||
|
Remove-Item git-sdk-64-minimal.zip
|
||||||
# Helper to initialize (or update) a Git worktree
|
|
||||||
function init ($path, $url, $set_origin) {
|
|
||||||
if (Test-Path $path) {
|
|
||||||
cd $path; c
|
|
||||||
if (Test-Path .git) {
|
|
||||||
& git init; c
|
|
||||||
} else {
|
|
||||||
& git status
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
& git init $path; c
|
|
||||||
cd $path; c
|
|
||||||
}
|
|
||||||
& git config core.autocrlf false; c
|
|
||||||
& git config core.untrackedCache true; c
|
|
||||||
if (($set_origin -ne 0) -and !(git config remote.origin.url)) {
|
|
||||||
& git remote add origin $url; c
|
|
||||||
}
|
|
||||||
& git fetch --depth=1 $url master; c
|
|
||||||
& git reset --hard FETCH_HEAD; c
|
|
||||||
& git clean -df; c
|
|
||||||
}
|
|
||||||
|
|
||||||
# Initialize Git for Windows' SDK
|
|
||||||
$sdk_path = "$(Build.SourcesDirectory)\git-sdk-64"
|
|
||||||
init "$sdk_path" "https://dev.azure.com/git-for-windows/git-sdk-64/_git/git-sdk-64" 0
|
|
||||||
|
|
||||||
# Let Git ignore the SDK and the test-cache
|
# Let Git ignore the SDK and the test-cache
|
||||||
"/git-sdk-64/`n/test-cache/`n" | Out-File -NoNewLine -Encoding ascii -Append "$(Build.SourcesDirectory)\.git\info\exclude"
|
"/git-sdk-64-minimal/`n/test-cache/`n" | Out-File -NoNewLine -Encoding ascii -Append "$(Build.SourcesDirectory)\.git\info\exclude"
|
||||||
displayName: 'Initialize the Git for Windows SDK'
|
displayName: 'Download git-sdk-64-minimal'
|
||||||
- powershell: |
|
- powershell: |
|
||||||
& "git-sdk-64\git-cmd.exe" --command=usr\\bin\\bash.exe -lc @"
|
& git-sdk-64-minimal\usr\bin\bash.exe -lc @"
|
||||||
export DEVELOPER=1
|
export DEVELOPER=1
|
||||||
export NO_PERL=1
|
export NO_PERL=1
|
||||||
export NO_SVN_TESTS=1
|
export NO_SVN_TESTS=1
|
||||||
|
Loading…
Reference in New Issue
Block a user