Commit b3ae845
CI: Test sdist completeness for all user-facing packages on Linux and Windows (#1909)
* CI: Test sdist builds for all user-facing packages
Add a new test-sdist workflow that builds an sdist and then a
wheel-from-sdist for each of the 4 user-facing packages
(cuda_pathfinder, cuda_python, cuda_bindings, cuda_core). This
catches regressions in MANIFEST.in or package-data configuration
that could silently break sdist-based builds.
Closes #1599
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* fix: skip test-sdist job on doc-only PRs
Match existing test jobs' doc-only guard so docs-only PRs don't
run source-build validation.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* fix: point cuda_bindings sdist build at local cuda_pathfinder wheel
cuda_bindings build backend imports cuda.pathfinder, so pip's build
isolation needs to find the locally-built cuda_pathfinder wheel
instead of pulling from PyPI. Set PIP_FIND_LINKS to the pathfinder
dist directory.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* Add actionlint config for self-hosted runner labels
actionlint rejects non-GitHub-hosted runner labels unless declared
in .github/actionlint.yaml. This was causing pre-commit.ci failures
on test-sdist.yml which uses linux-amd64-cpu8.
Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
* ci: add Windows sdist completeness test alongside Linux
Split test-sdist.yml into test-sdist-linux.yml (renamed) and a new
test-sdist-windows.yml sibling, mirroring the test-wheel-linux/-windows
pattern. cuda_bindings/build_hooks.py selects platform-specific *.pyx
variants (_linux.pyx on Linux, _windows.pyx on Windows) at build time,
so a Linux-only sdist test cannot prove the sdist ships the Windows
sources required to build a wheel-from-sdist on Windows.
The Windows variant uses the repo's windows-2022 + ilammy/msvc-dev-cmd
setup already used by build-wheel.yml, omits sccache and
nv-gha-runners/setup-proxy-cache (both limited to Linux in build-wheel
by convention), and otherwise mirrors the Linux steps.
ci.yml now invokes both workflows (test-sdist-linux, test-sdist-windows)
and the checks aggregator fails if either is cancelled or failed.
Addresses review feedback from PR #1909.
* ci: normalize Windows PIP_FIND_LINKS via cygpath
Convert the find-links paths to native Windows style with cygpath -w so
they match the convention used in build-wheel.yml's Windows CIBW
environment. This avoids ambiguity when pip splits PIP_FIND_LINKS on
spaces and is asked to resolve a mix of path styles.
---------
Co-authored-by: Claude Opus 4.6 (1M context) <noreply@anthropic.com>1 parent b427919 commit b3ae845
File tree
4 files changed
+246
-0
lines changed- .github
- workflows
4 files changed
+246
-0
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
286 | 286 | | |
287 | 287 | | |
288 | 288 | | |
| 289 | + | |
| 290 | + | |
| 291 | + | |
| 292 | + | |
| 293 | + | |
| 294 | + | |
| 295 | + | |
| 296 | + | |
| 297 | + | |
| 298 | + | |
| 299 | + | |
| 300 | + | |
| 301 | + | |
| 302 | + | |
| 303 | + | |
| 304 | + | |
| 305 | + | |
| 306 | + | |
| 307 | + | |
| 308 | + | |
| 309 | + | |
| 310 | + | |
| 311 | + | |
| 312 | + | |
| 313 | + | |
| 314 | + | |
| 315 | + | |
| 316 | + | |
| 317 | + | |
| 318 | + | |
| 319 | + | |
289 | 320 | | |
290 | 321 | | |
291 | 322 | | |
| |||
388 | 419 | | |
389 | 420 | | |
390 | 421 | | |
| 422 | + | |
| 423 | + | |
391 | 424 | | |
392 | 425 | | |
393 | 426 | | |
| |||
427 | 460 | | |
428 | 461 | | |
429 | 462 | | |
| 463 | + | |
| 464 | + | |
| 465 | + | |
| 466 | + | |
| 467 | + | |
| 468 | + | |
430 | 469 | | |
431 | 470 | | |
432 | 471 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
0 commit comments