]> git.ipfire.org Git - thirdparty/git.git/blob - .github/workflows/main.yml
Merge branch 'jc/bisect-doc' into maint-2.43
[thirdparty/git.git] / .github / workflows / main.yml
1 name: CI
2
3 on: [push, pull_request]
4
5 env:
6 DEVELOPER: 1
7
8 # If more than one workflow run is triggered for the very same commit hash
9 # (which happens when multiple branches pointing to the same commit), only
10 # the first one is allowed to run, the second will be kept in the "queued"
11 # state. This allows a successful completion of the first run to be reused
12 # in the second run via the `skip-if-redundant` logic in the `config` job.
13 #
14 # The only caveat is that if a workflow run is triggered for the same commit
15 # hash that another run is already being held, that latter run will be
16 # canceled. For more details about the `concurrency` attribute, see:
17 # https://docs.github.com/en/actions/using-workflows/workflow-syntax-for-github-actions#concurrency
18 concurrency:
19 group: ${{ github.sha }}
20
21 jobs:
22 ci-config:
23 name: config
24 if: vars.CI_BRANCHES == '' || contains(vars.CI_BRANCHES, github.ref_name)
25 runs-on: ubuntu-latest
26 outputs:
27 enabled: ${{ steps.check-ref.outputs.enabled }}${{ steps.skip-if-redundant.outputs.enabled }}
28 skip_concurrent: ${{ steps.check-ref.outputs.skip_concurrent }}
29 steps:
30 - name: try to clone ci-config branch
31 run: |
32 git -c protocol.version=2 clone \
33 --no-tags \
34 --single-branch \
35 -b ci-config \
36 --depth 1 \
37 --no-checkout \
38 --filter=blob:none \
39 https://github.com/${{ github.repository }} \
40 config-repo &&
41 cd config-repo &&
42 git checkout HEAD -- ci/config || : ignore
43 - id: check-ref
44 name: check whether CI is enabled for ref
45 run: |
46 enabled=yes
47 if test -x config-repo/ci/config/allow-ref
48 then
49 echo "::warning::ci/config/allow-ref is deprecated; use CI_BRANCHES instead"
50 if ! config-repo/ci/config/allow-ref '${{ github.ref }}'
51 then
52 enabled=no
53 fi
54 fi
55
56 skip_concurrent=yes
57 if test -x config-repo/ci/config/skip-concurrent &&
58 ! config-repo/ci/config/skip-concurrent '${{ github.ref }}'
59 then
60 skip_concurrent=no
61 fi
62 echo "enabled=$enabled" >>$GITHUB_OUTPUT
63 echo "skip_concurrent=$skip_concurrent" >>$GITHUB_OUTPUT
64 - name: skip if the commit or tree was already tested
65 id: skip-if-redundant
66 uses: actions/github-script@v6
67 if: steps.check-ref.outputs.enabled == 'yes'
68 with:
69 github-token: ${{secrets.GITHUB_TOKEN}}
70 script: |
71 try {
72 // Figure out workflow ID, commit and tree
73 const { data: run } = await github.rest.actions.getWorkflowRun({
74 owner: context.repo.owner,
75 repo: context.repo.repo,
76 run_id: context.runId,
77 });
78 const workflow_id = run.workflow_id;
79 const head_sha = run.head_sha;
80 const tree_id = run.head_commit.tree_id;
81
82 // See whether there is a successful run for that commit or tree
83 const { data: runs } = await github.rest.actions.listWorkflowRuns({
84 owner: context.repo.owner,
85 repo: context.repo.repo,
86 per_page: 500,
87 status: 'success',
88 workflow_id,
89 });
90 for (const run of runs.workflow_runs) {
91 if (head_sha === run.head_sha) {
92 core.warning(`Successful run for the commit ${head_sha}: ${run.html_url}`);
93 core.setOutput('enabled', ' but skip');
94 break;
95 }
96 if (run.head_commit && tree_id === run.head_commit.tree_id) {
97 core.warning(`Successful run for the tree ${tree_id}: ${run.html_url}`);
98 core.setOutput('enabled', ' but skip');
99 break;
100 }
101 }
102 } catch (e) {
103 core.warning(e);
104 }
105
106 windows-build:
107 name: win build
108 needs: ci-config
109 if: needs.ci-config.outputs.enabled == 'yes'
110 runs-on: windows-latest
111 concurrency:
112 group: windows-build-${{ github.ref }}
113 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
114 steps:
115 - uses: actions/checkout@v3
116 - uses: git-for-windows/setup-git-for-windows-sdk@v1
117 - name: build
118 shell: bash
119 env:
120 HOME: ${{runner.workspace}}
121 NO_PERL: 1
122 run: . /etc/profile && ci/make-test-artifacts.sh artifacts
123 - name: zip up tracked files
124 run: git archive -o artifacts/tracked.tar.gz HEAD
125 - name: upload tracked files and build artifacts
126 uses: actions/upload-artifact@v3
127 with:
128 name: windows-artifacts
129 path: artifacts
130 windows-test:
131 name: win test
132 runs-on: windows-latest
133 needs: [ci-config, windows-build]
134 strategy:
135 fail-fast: false
136 matrix:
137 nr: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
138 concurrency:
139 group: windows-test-${{ matrix.nr }}-${{ github.ref }}
140 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
141 steps:
142 - name: download tracked files and build artifacts
143 uses: actions/download-artifact@v3
144 with:
145 name: windows-artifacts
146 path: ${{github.workspace}}
147 - name: extract tracked files and build artifacts
148 shell: bash
149 run: tar xf artifacts.tar.gz && tar xf tracked.tar.gz
150 - uses: git-for-windows/setup-git-for-windows-sdk@v1
151 - name: test
152 shell: bash
153 run: . /etc/profile && ci/run-test-slice.sh ${{matrix.nr}} 10
154 - name: print test failures
155 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
156 shell: bash
157 run: ci/print-test-failures.sh
158 - name: Upload failed tests' directories
159 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
160 uses: actions/upload-artifact@v3
161 with:
162 name: failed-tests-windows
163 path: ${{env.FAILED_TEST_ARTIFACTS}}
164 vs-build:
165 name: win+VS build
166 needs: ci-config
167 if: github.event.repository.owner.login == 'git-for-windows' && needs.ci-config.outputs.enabled == 'yes'
168 env:
169 NO_PERL: 1
170 GIT_CONFIG_PARAMETERS: "'user.name=CI' 'user.email=ci@git'"
171 runs-on: windows-latest
172 concurrency:
173 group: vs-build-${{ github.ref }}
174 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
175 steps:
176 - uses: actions/checkout@v3
177 - uses: git-for-windows/setup-git-for-windows-sdk@v1
178 - name: initialize vcpkg
179 uses: actions/checkout@v3
180 with:
181 repository: 'microsoft/vcpkg'
182 path: 'compat/vcbuild/vcpkg'
183 - name: download vcpkg artifacts
184 shell: powershell
185 run: |
186 $urlbase = "https://dev.azure.com/git/git/_apis/build/builds"
187 $id = ((Invoke-WebRequest -UseBasicParsing "${urlbase}?definitions=9&statusFilter=completed&resultFilter=succeeded&`$top=1").content | ConvertFrom-JSON).value[0].id
188 $downloadUrl = ((Invoke-WebRequest -UseBasicParsing "${urlbase}/$id/artifacts").content | ConvertFrom-JSON).value[0].resource.downloadUrl
189 (New-Object Net.WebClient).DownloadFile($downloadUrl, "compat.zip")
190 Expand-Archive compat.zip -DestinationPath . -Force
191 Remove-Item compat.zip
192 - name: add msbuild to PATH
193 uses: microsoft/setup-msbuild@v1
194 - name: copy dlls to root
195 shell: cmd
196 run: compat\vcbuild\vcpkg_copy_dlls.bat release
197 - name: generate Visual Studio solution
198 shell: bash
199 run: |
200 cmake `pwd`/contrib/buildsystems/ -DCMAKE_PREFIX_PATH=`pwd`/compat/vcbuild/vcpkg/installed/x64-windows \
201 -DNO_GETTEXT=YesPlease -DPERL_TESTS=OFF -DPYTHON_TESTS=OFF -DCURL_NO_CURL_CMAKE=ON
202 - name: MSBuild
203 run: msbuild git.sln -property:Configuration=Release -property:Platform=x64 -maxCpuCount:4 -property:PlatformToolset=v142
204 - name: bundle artifact tar
205 shell: bash
206 env:
207 MSVC: 1
208 VCPKG_ROOT: ${{github.workspace}}\compat\vcbuild\vcpkg
209 run: |
210 mkdir -p artifacts &&
211 eval "$(make -n artifacts-tar INCLUDE_DLLS_IN_ARTIFACTS=YesPlease ARTIFACTS_DIRECTORY=artifacts NO_GETTEXT=YesPlease 2>&1 | grep ^tar)"
212 - name: zip up tracked files
213 run: git archive -o artifacts/tracked.tar.gz HEAD
214 - name: upload tracked files and build artifacts
215 uses: actions/upload-artifact@v3
216 with:
217 name: vs-artifacts
218 path: artifacts
219 vs-test:
220 name: win+VS test
221 runs-on: windows-latest
222 needs: [ci-config, vs-build]
223 strategy:
224 fail-fast: false
225 matrix:
226 nr: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
227 concurrency:
228 group: vs-test-${{ matrix.nr }}-${{ github.ref }}
229 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
230 steps:
231 - uses: git-for-windows/setup-git-for-windows-sdk@v1
232 - name: download tracked files and build artifacts
233 uses: actions/download-artifact@v3
234 with:
235 name: vs-artifacts
236 path: ${{github.workspace}}
237 - name: extract tracked files and build artifacts
238 shell: bash
239 run: tar xf artifacts.tar.gz && tar xf tracked.tar.gz
240 - name: test
241 shell: bash
242 env:
243 NO_SVN_TESTS: 1
244 run: . /etc/profile && ci/run-test-slice.sh ${{matrix.nr}} 10
245 - name: print test failures
246 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
247 shell: bash
248 run: ci/print-test-failures.sh
249 - name: Upload failed tests' directories
250 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
251 uses: actions/upload-artifact@v3
252 with:
253 name: failed-tests-windows
254 path: ${{env.FAILED_TEST_ARTIFACTS}}
255 regular:
256 name: ${{matrix.vector.jobname}} (${{matrix.vector.pool}})
257 needs: ci-config
258 if: needs.ci-config.outputs.enabled == 'yes'
259 concurrency:
260 group: ${{ matrix.vector.jobname }}-${{ matrix.vector.pool }}-${{ github.ref }}
261 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
262 strategy:
263 fail-fast: false
264 matrix:
265 vector:
266 - jobname: linux-sha256
267 cc: clang
268 pool: ubuntu-latest
269 - jobname: linux-gcc
270 cc: gcc
271 cc_package: gcc-8
272 pool: ubuntu-20.04
273 - jobname: linux-TEST-vars
274 cc: gcc
275 cc_package: gcc-8
276 pool: ubuntu-20.04
277 - jobname: osx-clang
278 cc: clang
279 pool: macos-13
280 - jobname: osx-gcc
281 cc: gcc
282 cc_package: gcc-13
283 pool: macos-13
284 - jobname: linux-gcc-default
285 cc: gcc
286 pool: ubuntu-latest
287 - jobname: linux-leaks
288 cc: gcc
289 pool: ubuntu-latest
290 - jobname: linux-asan-ubsan
291 cc: clang
292 pool: ubuntu-latest
293 env:
294 CC: ${{matrix.vector.cc}}
295 CC_PACKAGE: ${{matrix.vector.cc_package}}
296 jobname: ${{matrix.vector.jobname}}
297 runs_on_pool: ${{matrix.vector.pool}}
298 runs-on: ${{matrix.vector.pool}}
299 steps:
300 - uses: actions/checkout@v3
301 - run: ci/install-dependencies.sh
302 - run: ci/run-build-and-tests.sh
303 - name: print test failures
304 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
305 run: ci/print-test-failures.sh
306 - name: Upload failed tests' directories
307 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
308 uses: actions/upload-artifact@v3
309 with:
310 name: failed-tests-${{matrix.vector.jobname}}
311 path: ${{env.FAILED_TEST_ARTIFACTS}}
312 dockerized:
313 name: ${{matrix.vector.jobname}} (${{matrix.vector.image}})
314 needs: ci-config
315 if: needs.ci-config.outputs.enabled == 'yes'
316 concurrency:
317 group: dockerized-${{ matrix.vector.jobname }}-${{ matrix.vector.image }}-${{ github.ref }}
318 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
319 strategy:
320 fail-fast: false
321 matrix:
322 vector:
323 - jobname: linux-musl
324 image: alpine
325 - jobname: linux32
326 image: daald/ubuntu32:xenial
327 - jobname: pedantic
328 image: fedora
329 env:
330 jobname: ${{matrix.vector.jobname}}
331 runs-on: ubuntu-latest
332 container: ${{matrix.vector.image}}
333 steps:
334 - uses: actions/checkout@v3
335 if: matrix.vector.jobname != 'linux32'
336 - uses: actions/checkout@v1
337 if: matrix.vector.jobname == 'linux32'
338 - run: ci/install-docker-dependencies.sh
339 - run: ci/run-build-and-tests.sh
340 - name: print test failures
341 if: failure() && env.FAILED_TEST_ARTIFACTS != ''
342 run: ci/print-test-failures.sh
343 - name: Upload failed tests' directories
344 if: failure() && env.FAILED_TEST_ARTIFACTS != '' && matrix.vector.jobname != 'linux32'
345 uses: actions/upload-artifact@v3
346 with:
347 name: failed-tests-${{matrix.vector.jobname}}
348 path: ${{env.FAILED_TEST_ARTIFACTS}}
349 - name: Upload failed tests' directories
350 if: failure() && env.FAILED_TEST_ARTIFACTS != '' && matrix.vector.jobname == 'linux32'
351 uses: actions/upload-artifact@v1
352 with:
353 name: failed-tests-${{matrix.vector.jobname}}
354 path: ${{env.FAILED_TEST_ARTIFACTS}}
355 static-analysis:
356 needs: ci-config
357 if: needs.ci-config.outputs.enabled == 'yes'
358 env:
359 jobname: StaticAnalysis
360 runs-on: ubuntu-22.04
361 concurrency:
362 group: static-analysis-${{ github.ref }}
363 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
364 steps:
365 - uses: actions/checkout@v3
366 - run: ci/install-dependencies.sh
367 - run: ci/run-static-analysis.sh
368 - run: ci/check-directional-formatting.bash
369 sparse:
370 needs: ci-config
371 if: needs.ci-config.outputs.enabled == 'yes'
372 env:
373 jobname: sparse
374 runs-on: ubuntu-20.04
375 concurrency:
376 group: sparse-${{ github.ref }}
377 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
378 steps:
379 - name: Download a current `sparse` package
380 # Ubuntu's `sparse` version is too old for us
381 uses: git-for-windows/get-azure-pipelines-artifact@v0
382 with:
383 repository: git/git
384 definitionId: 10
385 artifact: sparse-20.04
386 - name: Install the current `sparse` package
387 run: sudo dpkg -i sparse-20.04/sparse_*.deb
388 - uses: actions/checkout@v3
389 - name: Install other dependencies
390 run: ci/install-dependencies.sh
391 - run: make sparse
392 documentation:
393 name: documentation
394 needs: ci-config
395 if: needs.ci-config.outputs.enabled == 'yes'
396 concurrency:
397 group: documentation-${{ github.ref }}
398 cancel-in-progress: ${{ needs.ci-config.outputs.skip_concurrent == 'yes' }}
399 env:
400 jobname: Documentation
401 runs-on: ubuntu-latest
402 steps:
403 - uses: actions/checkout@v3
404 - run: ci/install-dependencies.sh
405 - run: ci/test-documentation.sh