From 594d69e7f32fe1b897d64df47ebade0367a3cc97 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 16:50:21 -0700 Subject: [PATCH 01/10] force install with pip --- .github/workflows/test-upstream.yaml | 21 +++++++++------------ 1 file changed, 9 insertions(+), 12 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index c009610f..8a6508d2 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -61,17 +61,6 @@ jobs: path: linkml/.venv key: venv-${{ matrix.python-version }}-${{ runner.os }}-${{ hashFiles('**/poetry.lock') }} - # make extra sure we're removing any old version of linkml-runtime that exists - - name: uninstall potentially cached linkml-runtime - working-directory: linkml - run: poetry run pip uninstall linkml-runtime - - # we are not using linkml-runtime's lockfile, but simulating what will happen - # when we merge this and update linkml's lockfile - - name: add linkml-runtime to lockfile - working-directory: linkml - run: poetry add ../linkml-runtime - # use correct pydantic version - name: install pydantic working-directory: linkml @@ -83,7 +72,15 @@ jobs: # the cache will still speedup the rest of the installation - name: install linkml working-directory: linkml - run: poetry install --no-interaction -E tests + run: poetry install --no-interaction --no-root -E tests + + # force install the local version of linkml-runtime + # we don't use poetry's lockfile here because according to poetry-dynamic-versioning: + # "The dynamic version is not available during poetry run or poetry shell because of a Poetry design choice that prevents the plugin from cleaning up after itself." + # and since linkml depends on a specific version of linkml-runtime, this would always fail + - name: install linkml-runtime in linkml's venv + working-directory: linkml + run: poetry run pip install --force-reinstall ../linkml-runtime - name: print linkml-runtime version working-directory: linkml From 979be6715fdec0e3bdc791effc70a20c0c09ff86 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 16:57:31 -0700 Subject: [PATCH 02/10] does using bash fix windows --- .github/workflows/test-upstream.yaml | 3 +++ 1 file changed, 3 insertions(+) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 8a6508d2..e59d4041 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -24,6 +24,9 @@ jobs: - python-version: "3.10" pydantic-version: "1" runs-on: ${{ matrix.os }} + defaults: + run: + shell: bash steps: From 35abb4cc8e66f85cb062c87d50865d8e60407afb Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 17:50:04 -0700 Subject: [PATCH 03/10] try and use poetry lockfile by overriding dynamic version --- .github/workflows/test-upstream.yaml | 24 ++++++++++++++++-------- 1 file changed, 16 insertions(+), 8 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index e59d4041..97bd5c5b 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -69,6 +69,22 @@ jobs: working-directory: linkml run: poetry add pydantic@^${{ matrix.pydantic-version }} + - name: remove potentially cached linkml-runtime version + working-directory: linkml + run: poetry run pip uninstall linkml-runtime + + # install the local version of linkml-runtime: + # we do this vs. pip --force-reinstall so that we keep linkml's locked deps + # and simulate what the lockfile will be after merging and relocking. + # we override the linkml-runtime version here according to poetry-dynamic-versioning: + # "The dynamic version is not available during poetry run or poetry shell because of a Poetry design choice that prevents the plugin from cleaning up after itself." + # and since linkml depends on a specific version of linkml-runtime, this would always fail + - name: add linkml-runtime to linkml's venv + working-directory: linkml + env: + POETRY_DYNAMIC_VERSIONING_OVERRIDE: "linkml-runtime = 1.99.0" + run: poetry add ../linkml-runtime + # note that we run the installation step always, even if we restore a venv, # the cache will restore the old version of linkml-runtime, but the lockfile # will only store the directory dependency (and thus will reinstall it) @@ -77,14 +93,6 @@ jobs: working-directory: linkml run: poetry install --no-interaction --no-root -E tests - # force install the local version of linkml-runtime - # we don't use poetry's lockfile here because according to poetry-dynamic-versioning: - # "The dynamic version is not available during poetry run or poetry shell because of a Poetry design choice that prevents the plugin from cleaning up after itself." - # and since linkml depends on a specific version of linkml-runtime, this would always fail - - name: install linkml-runtime in linkml's venv - working-directory: linkml - run: poetry run pip install --force-reinstall ../linkml-runtime - - name: print linkml-runtime version working-directory: linkml run: poetry run python -c 'import linkml_runtime; from importlib.metadata import version; print(linkml_runtime.__file__); print(version("linkml_runtime"))' From a26160725a757fed7ec0077d8b101e81b65f1baf Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 17:59:20 -0700 Subject: [PATCH 04/10] approve uninstalling linkml-runtime, add short hash to version --- .github/workflows/test-upstream.yaml | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 97bd5c5b..2b73af0d 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -71,7 +71,13 @@ jobs: - name: remove potentially cached linkml-runtime version working-directory: linkml - run: poetry run pip uninstall linkml-runtime + run: poetry run pip uninstall linkml-runtime -y + + - name: get linkml-runtime short hash + working-directory: linkml-runtime + run: | + LINKML_RUNTIME_COMMIT=$(git rev-parse --short HEAD) + echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" # install the local version of linkml-runtime: # we do this vs. pip --force-reinstall so that we keep linkml's locked deps @@ -82,7 +88,7 @@ jobs: - name: add linkml-runtime to linkml's venv working-directory: linkml env: - POETRY_DYNAMIC_VERSIONING_OVERRIDE: "linkml-runtime = 1.99.0" + POETRY_DYNAMIC_VERSIONING_OVERRIDE: "linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" run: poetry add ../linkml-runtime # note that we run the installation step always, even if we restore a venv, From 0fc713c69c6e40b2d9534439dc806b872e94057f Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:05:08 -0700 Subject: [PATCH 05/10] I guess it needs to be set inline? --- .github/workflows/test-upstream.yaml | 4 +--- 1 file changed, 1 insertion(+), 3 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 2b73af0d..a6f77592 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -87,9 +87,7 @@ jobs: # and since linkml depends on a specific version of linkml-runtime, this would always fail - name: add linkml-runtime to linkml's venv working-directory: linkml - env: - POETRY_DYNAMIC_VERSIONING_OVERRIDE: "linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" - run: poetry add ../linkml-runtime + run: POETRY_DYNAMIC_VERSIONING_OVERRIDE="linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry add ../linkml-runtime # note that we run the installation step always, even if we restore a venv, # the cache will restore the old version of linkml-runtime, but the lockfile From df020949ec2597ae79741b83cc239cfa79e1c85e Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:35:31 -0700 Subject: [PATCH 06/10] multistage wheel build strategy --- .github/workflows/test-upstream.yaml | 81 +++++++++++++++++++--------- 1 file changed, 56 insertions(+), 25 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index a6f77592..497690c4 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -1,3 +1,11 @@ +# This action is split up into two phases because +# - We want to test linkml-runtime against linkml's lockfile - so we can't pip install --force-reinstall the local version +# - We want to also take into account any deps changes linkml-runtime might have - so we can't pip install --no-deps +# - We need to actually be able to install linkml-runtime, and since dynamic versioning doesn't work and can't be forced with +# env vars from another project... +# We build a wheel with an artificially high version first, and then share that to the upstream tests +# The linkml-runtime wheel should be the same across OS and python versions (and is actually an additional test of our packaging) + name: Test with upstream linkml on: pull_request_review: @@ -5,7 +13,46 @@ on: workflow_dispatch: jobs: + build_wheel: + if: github.event_name == 'workflow_dispatch' || github.event.review.state == 'APPROVED' + runs-on: ubuntu-latest + defaults: + run: + shell: bash + outputs: + linkml-runtime-wheel: ${{ steps.wheel-upload.outputs.artifact-id }} + + steps: + - name: checkout linkml-runtime + uses: actions/checkout@v4 + - name: set up python + uses: actions/setup-python@v5 + with: + python-version: "3.11" + - name: install poetry + uses: snok/install-poetry@v1 + with: + virtualenvs-create: true + virtualenvs-in-project: true + - name: get linkml-runtime short hash + run: | + LINKML_RUNTIME_COMMIT=$(git rev-parse --short HEAD) + echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" + - name: build linkml-runtime wheel + run: | + POETRY_DYNAMIC_VERSIONING_BYPASS="1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry build + - name: upload dist directory + uses: actions/upload-artifact@v4 + id: wheel-upload + with: + name: linkml-runtime-wheel + path: dist/ + if-no-files-found: error + overwrite: true + retention-days: 5 + test_upstream: + needs: build_wheel if: github.event_name == 'workflow_dispatch' || github.event.review.state == 'APPROVED' strategy: matrix: @@ -38,14 +85,6 @@ jobs: ref: main fetch-depth: 0 - - name: checkout linkml-runtime - uses: actions/checkout@v4 - with: - # don't specify repository like this or else we won't get pull request branches correctly - # repository: linkml/linkml-runtime - path: linkml-runtime - fetch-depth: 0 - - name: set up python uses: actions/setup-python@v5 with: @@ -73,26 +112,18 @@ jobs: working-directory: linkml run: poetry run pip uninstall linkml-runtime -y - - name: get linkml-runtime short hash - working-directory: linkml-runtime - run: | - LINKML_RUNTIME_COMMIT=$(git rev-parse --short HEAD) - echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" + # this should unpack into dist/ + - name: Download the built wheel + uses: actions/download-artifact@v4 + with: + name: ${{ needs.build_wheel.outputs.linkml-runtime-wheel }} - # install the local version of linkml-runtime: - # we do this vs. pip --force-reinstall so that we keep linkml's locked deps - # and simulate what the lockfile will be after merging and relocking. - # we override the linkml-runtime version here according to poetry-dynamic-versioning: - # "The dynamic version is not available during poetry run or poetry shell because of a Poetry design choice that prevents the plugin from cleaning up after itself." - # and since linkml depends on a specific version of linkml-runtime, this would always fail - - name: add linkml-runtime to linkml's venv + # amazingly, poetry does find the wheel correctly + - name: add linkml-runtime wheel to linkml's venv working-directory: linkml - run: POETRY_DYNAMIC_VERSIONING_OVERRIDE="linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry add ../linkml-runtime + run: poetry add ./dist/* - # note that we run the installation step always, even if we restore a venv, - # the cache will restore the old version of linkml-runtime, but the lockfile - # will only store the directory dependency (and thus will reinstall it) - # the cache will still speedup the rest of the installation + # with the modifications to the lockfile, we can install the rest of the deps - name: install linkml working-directory: linkml run: poetry install --no-interaction --no-root -E tests From 5bca56c4017e7558949b5f4b3a5168eee6cf5f25 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:38:42 -0700 Subject: [PATCH 07/10] what in the world, why isn't dynamic versioning running --- .github/workflows/test-upstream.yaml | 1 + 1 file changed, 1 insertion(+) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 497690c4..267c0ee7 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -40,6 +40,7 @@ jobs: echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" - name: build linkml-runtime wheel run: | + poetry self add "poetry-dynamic-versioning[plugin]" POETRY_DYNAMIC_VERSIONING_BYPASS="1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry build - name: upload dist directory uses: actions/upload-artifact@v4 From 6a5abf931316aed1b94495f4014506051cc0c1a7 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:42:37 -0700 Subject: [PATCH 08/10] Revert "what in the world, why isn't dynamic versioning running" This reverts commit 5bca56c4017e7558949b5f4b3a5168eee6cf5f25. --- .github/workflows/test-upstream.yaml | 1 - 1 file changed, 1 deletion(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 267c0ee7..497690c4 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -40,7 +40,6 @@ jobs: echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" - name: build linkml-runtime wheel run: | - poetry self add "poetry-dynamic-versioning[plugin]" POETRY_DYNAMIC_VERSIONING_BYPASS="1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry build - name: upload dist directory uses: actions/upload-artifact@v4 From 2b453e37f1c00055f5bb55602b73355cf2309944 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:42:37 -0700 Subject: [PATCH 09/10] Revert "multistage wheel build strategy" This reverts commit df020949ec2597ae79741b83cc239cfa79e1c85e. --- .github/workflows/test-upstream.yaml | 81 +++++++++------------------- 1 file changed, 25 insertions(+), 56 deletions(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index 497690c4..a6f77592 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -1,11 +1,3 @@ -# This action is split up into two phases because -# - We want to test linkml-runtime against linkml's lockfile - so we can't pip install --force-reinstall the local version -# - We want to also take into account any deps changes linkml-runtime might have - so we can't pip install --no-deps -# - We need to actually be able to install linkml-runtime, and since dynamic versioning doesn't work and can't be forced with -# env vars from another project... -# We build a wheel with an artificially high version first, and then share that to the upstream tests -# The linkml-runtime wheel should be the same across OS and python versions (and is actually an additional test of our packaging) - name: Test with upstream linkml on: pull_request_review: @@ -13,46 +5,7 @@ on: workflow_dispatch: jobs: - build_wheel: - if: github.event_name == 'workflow_dispatch' || github.event.review.state == 'APPROVED' - runs-on: ubuntu-latest - defaults: - run: - shell: bash - outputs: - linkml-runtime-wheel: ${{ steps.wheel-upload.outputs.artifact-id }} - - steps: - - name: checkout linkml-runtime - uses: actions/checkout@v4 - - name: set up python - uses: actions/setup-python@v5 - with: - python-version: "3.11" - - name: install poetry - uses: snok/install-poetry@v1 - with: - virtualenvs-create: true - virtualenvs-in-project: true - - name: get linkml-runtime short hash - run: | - LINKML_RUNTIME_COMMIT=$(git rev-parse --short HEAD) - echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" - - name: build linkml-runtime wheel - run: | - POETRY_DYNAMIC_VERSIONING_BYPASS="1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry build - - name: upload dist directory - uses: actions/upload-artifact@v4 - id: wheel-upload - with: - name: linkml-runtime-wheel - path: dist/ - if-no-files-found: error - overwrite: true - retention-days: 5 - test_upstream: - needs: build_wheel if: github.event_name == 'workflow_dispatch' || github.event.review.state == 'APPROVED' strategy: matrix: @@ -85,6 +38,14 @@ jobs: ref: main fetch-depth: 0 + - name: checkout linkml-runtime + uses: actions/checkout@v4 + with: + # don't specify repository like this or else we won't get pull request branches correctly + # repository: linkml/linkml-runtime + path: linkml-runtime + fetch-depth: 0 + - name: set up python uses: actions/setup-python@v5 with: @@ -112,18 +73,26 @@ jobs: working-directory: linkml run: poetry run pip uninstall linkml-runtime -y - # this should unpack into dist/ - - name: Download the built wheel - uses: actions/download-artifact@v4 - with: - name: ${{ needs.build_wheel.outputs.linkml-runtime-wheel }} + - name: get linkml-runtime short hash + working-directory: linkml-runtime + run: | + LINKML_RUNTIME_COMMIT=$(git rev-parse --short HEAD) + echo "LINKML_RUNTIME_COMMIT=$LINKML_RUNTIME_COMMIT" >> "$GITHUB_ENV" - # amazingly, poetry does find the wheel correctly - - name: add linkml-runtime wheel to linkml's venv + # install the local version of linkml-runtime: + # we do this vs. pip --force-reinstall so that we keep linkml's locked deps + # and simulate what the lockfile will be after merging and relocking. + # we override the linkml-runtime version here according to poetry-dynamic-versioning: + # "The dynamic version is not available during poetry run or poetry shell because of a Poetry design choice that prevents the plugin from cleaning up after itself." + # and since linkml depends on a specific version of linkml-runtime, this would always fail + - name: add linkml-runtime to linkml's venv working-directory: linkml - run: poetry add ./dist/* + run: POETRY_DYNAMIC_VERSIONING_OVERRIDE="linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry add ../linkml-runtime - # with the modifications to the lockfile, we can install the rest of the deps + # note that we run the installation step always, even if we restore a venv, + # the cache will restore the old version of linkml-runtime, but the lockfile + # will only store the directory dependency (and thus will reinstall it) + # the cache will still speedup the rest of the installation - name: install linkml working-directory: linkml run: poetry install --no-interaction --no-root -E tests From 8a5dee20c79bf1eaf4b9e00d08582847c2f06906 Mon Sep 17 00:00:00 2001 From: sneakers-the-rat Date: Tue, 2 Apr 2024 18:43:29 -0700 Subject: [PATCH 10/10] do we just need to install the plugin... --- .github/workflows/test-upstream.yaml | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/.github/workflows/test-upstream.yaml b/.github/workflows/test-upstream.yaml index a6f77592..c5d9c835 100644 --- a/.github/workflows/test-upstream.yaml +++ b/.github/workflows/test-upstream.yaml @@ -87,7 +87,9 @@ jobs: # and since linkml depends on a specific version of linkml-runtime, this would always fail - name: add linkml-runtime to linkml's venv working-directory: linkml - run: POETRY_DYNAMIC_VERSIONING_OVERRIDE="linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry add ../linkml-runtime + run: | + poetry self add "poetry-dynamic-versioning[plugin]" + POETRY_DYNAMIC_VERSIONING_OVERRIDE="linkml-runtime = 1.99.0+${{ env.LINKML_RUNTIME_COMMIT }}" poetry add ../linkml-runtime # note that we run the installation step always, even if we restore a venv, # the cache will restore the old version of linkml-runtime, but the lockfile