Skip to content
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

Build wheels alongside conda CI #12427

Merged
merged 30 commits into from
Jan 10, 2023
Merged
Show file tree
Hide file tree
Changes from 8 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
628de05
Build wheels alongside conda CI
sevagh Dec 20, 2022
c51c692
Retrigger build
sevagh Dec 20, 2022
72ea6a4
Retrigger build
sevagh Dec 20, 2022
5cbaac4
Put wheel name at end of job name
sevagh Dec 20, 2022
f83d795
Use unified publish workflow
sevagh Dec 21, 2022
5eec7dd
Add wheel parameters to build.yaml inputs
sevagh Dec 21, 2022
fba1239
Separate publish workflows
sevagh Dec 21, 2022
a993a3f
Use bigger Pyarrow interop smoke test
sevagh Dec 21, 2022
0124cd1
Try escaped double-quotes instead
sevagh Dec 21, 2022
782b2af
Move smoke test to its own file
sevagh Dec 21, 2022
bb610d1
Add copyright to smoke test file
sevagh Dec 21, 2022
77d3694
Merge branch 'branch-23.02' into feat/wheels/py310-ctk12-wheels
ajschmidt8 Jan 5, 2023
bc578d8
fix copyright headers
ajschmidt8 Jan 5, 2023
1794af8
make wheel builds depend on `checks`
ajschmidt8 Jan 5, 2023
04e5add
Install pyarrow 10.0.1
sevagh Jan 6, 2023
68f3ee4
Add one more assert to smoke test; drop print statement
sevagh Jan 6, 2023
0aeabe2
Copyright fix in cudf/setup.py
sevagh Jan 6, 2023
4608733
Merge branch 'branch-23.02' into feat/wheels/py310-ctk12-wheels
sevagh Jan 6, 2023
5ea3a5f
Removed some wheel parameters
sevagh Jan 6, 2023
037ef3d
Update arrow versioning logic.
vyasr Jan 6, 2023
35a6c30
More accurate comment.
vyasr Jan 6, 2023
c070aa5
Use main version of improved wheel workflows
sevagh Jan 6, 2023
f81bc92
Use current-workflow cudf wheel for dask-cudf
sevagh Jan 9, 2023
5157326
Use branch of shared-action-workflows
sevagh Jan 9, 2023
22e3951
Pure wheels use test-before no arch
sevagh Jan 9, 2023
c364ec8
Use correct RAPIDS_PY_WHEEL_NAME
sevagh Jan 9, 2023
caa95a7
Trigger build
sevagh Jan 9, 2023
acf191e
Remove unneeded repo: keys
sevagh Jan 9, 2023
e214f83
Merge branch 'branch-23.02' into feat/wheels/py310-ctk12-wheels
ajschmidt8 Jan 9, 2023
6492d1a
before-wheel param is now supported by main workflow
sevagh Jan 9, 2023
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
56 changes: 56 additions & 0 deletions .github/workflows/build.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,12 @@ on:
build_type:
type: string
default: nightly
wheel_versioneer_override:
type: string
default: ''
wheel_build_tag:
type: string
default: ''

concurrency:
group: ${{ github.workflow }}-${{ github.ref }}
Expand Down Expand Up @@ -55,3 +61,53 @@ jobs:
branch: ${{ inputs.branch }}
date: ${{ inputs.date }}
sha: ${{ inputs.sha }}
wheel-build-cudf:
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-manylinux-build.yml@upkeep/manylinux-improvements
with:
build_type: ${{ inputs.build_type || 'branch' }}
repo: rapidsai/cudf
sevagh marked this conversation as resolved.
Show resolved Hide resolved
branch: ${{ inputs.branch }}
sha: ${{ inputs.sha }}
date: ${{ inputs.date }}
package-name: cudf
package-dir: python/cudf
versioneer-override: ${{ inputs.wheel_versioneer_override }}
skbuild-configure-options: "-DCUDF_BUILD_WHEELS=ON -DDETECT_CONDA_ENV=OFF"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We can leave this for now (something I will raise more broadly in the new year) but AFAIK this variable doesn't do anything right now. The question would be whether it should be set to do anything. That's a rapids-wide discussion though; I think only cuML is actively making use of this now and that's partly because it needs to forward along to deps like treelite.

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

wheel-publish-cudf:
needs: wheel-build-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-manylinux-publish.yml@upkeep/manylinux-improvements
with:
build_type: ${{ inputs.build_type || 'branch' }}
repo: rapidsai/cudf
branch: ${{ inputs.branch }}
sha: ${{ inputs.sha }}
date: ${{ inputs.date }}
package-name: cudf
build-tag: ${{ inputs.wheel_build_tag }}
wheel-build-dask-cudf:
needs: wheel-publish-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-pure-build.yml@upkeep/manylinux-improvements
with:
build_type: ${{ inputs.build_type || 'branch' }}
repo: rapidsai/cudf
branch: ${{ inputs.branch }}
sha: ${{ inputs.sha }}
date: ${{ inputs.date }}
package-name: dask_cudf
package-dir: python/dask_cudf
versioneer-override: ${{ inputs.wheel_versioneer_override }}
wheel-publish-dask-cudf:
needs: wheel-build-dask-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-pure-publish.yml@upkeep/manylinux-improvements
with:
build_type: ${{ inputs.build_type || 'branch' }}
repo: rapidsai/cudf
branch: ${{ inputs.branch }}
sha: ${{ inputs.sha }}
date: ${{ inputs.date }}
package-name: dask_cudf
build-tag: ${{ inputs.wheel_build_tag }}
38 changes: 38 additions & 0 deletions .github/workflows/pr.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,10 @@ jobs:
- conda-python-other-tests
- conda-java-tests
- conda-notebook-tests
- wheel-build-cudf
- wheel-tests-cudf
- wheel-build-dask-cudf
- wheel-tests-dask-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/pr-builder.yaml@main
checks:
Expand Down Expand Up @@ -78,3 +82,37 @@ jobs:
arch: "amd64"
container_image: "rapidsai/ci:latest"
run_script: "ci/test_notebooks.sh"
wheel-build-cudf:
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-manylinux-build.yml@upkeep/manylinux-improvements
with:
build_type: pull-request
package-name: cudf
package-dir: python/cudf
skbuild-configure-options: "-DCUDF_BUILD_WHEELS=ON -DDETECT_CONDA_ENV=OFF"
wheel-tests-cudf:
needs: wheel-build-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-manylinux-test.yml@upkeep/manylinux-improvements
with:
build_type: pull-request
package-name: cudf
test-before-arm64: "pip install tokenizers==0.10.2 cupy-cuda11x -f https://pip.cupy.dev/aarch64"
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Since it's already working we can leave it for now, but I'll note that in #12377 we actually removed tokenizers from arm tests and only test on x86 for conda packages.

test-unittest: "pytest -v -n 8 ./python/cudf/cudf/tests"
test-smoketest: "python -c 'import cudf; import pyarrow as pa; n_legs = pa.array([2, 4, 5, 100]); animals = pa.array([\'Flamingo\', \'Horse\', \'Brittle stars\', \'Centipede\']); names = [\'n_legs\', \'animals\']; print(animals); foo = pa.table([n_legs, animals], names=names); print(foo); df = cudf.DataFrame.from_arrow(foo); print(df); print(df.loc[df[\'animals\'] == \'Centipede\'][\'n_legs\']); assert df.loc[df[\'animals\'] == \'Centipede\'][\'n_legs\'].iloc[0] == 100'"
wheel-build-dask-cudf:
needs: wheel-build-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-pure-build.yml@upkeep/manylinux-improvements
with:
build_type: pull-request
package-name: dask_cudf
package-dir: python/dask_cudf
wheel-tests-dask-cudf:
needs: wheel-build-dask-cudf
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-pure-test.yml@upkeep/manylinux-improvements
with:
build_type: pull-request
package-name: dask_cudf
test-unittest: "pytest -v -n 8 ./python/dask_cudf/dask_cudf/tests"
23 changes: 23 additions & 0 deletions .github/workflows/test.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -70,3 +70,26 @@ jobs:
arch: "amd64"
container_image: "rapidsai/ci:latest"
run_script: "ci/test_notebooks.sh"
wheel-tests-cudf:
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-manylinux-test.yml@upkeep/manylinux-improvements
with:
build_type: nightly
repo: rapidsai/cudf
branch: ${{ inputs.branch }}
date: ${{ inputs.date }}
sha: ${{ inputs.sha }}
package-name: cudf
test-before-arm64: "pip install tokenizers==0.10.2 cupy-cuda11x -f https://pip.cupy.dev/aarch64"
test-unittest: "pytest -v -n 8 ./python/cudf/cudf/tests"
wheel-tests-dask-cudf:
secrets: inherit
uses: rapidsai/shared-action-workflows/.github/workflows/wheels-pure-test.yml@upkeep/manylinux-improvements
with:
build_type: nightly
repo: rapidsai/cudf
branch: ${{ inputs.branch }}
date: ${{ inputs.date }}
sha: ${{ inputs.sha }}
package-name: dask_cudf
test-unittest: "pytest -v -n 8 ./python/dask_cudf/dask_cudf/tests"
77 changes: 0 additions & 77 deletions .github/workflows/wheels.yml

This file was deleted.