External Dispatch #19
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| name: External Dispatch | |
| on: | |
| workflow_dispatch: | |
| inputs: | |
| duckdb-sha: | |
| type: string | |
| description: The DuckDB submodule commit to build against | |
| required: true | |
| commit-duckdb-sha: | |
| type: boolean | |
| description: Commit and push the DuckDB submodule ref | |
| default: false | |
| force-version: | |
| type: string | |
| description: Force version (vX.Y.Z-((rc|post)N)) | |
| required: false | |
| publish-packages: | |
| type: boolean | |
| description: Publish to S3 | |
| required: true | |
| default: false | |
| defaults: | |
| run: | |
| shell: bash | |
| jobs: | |
| commit_submodule: | |
| name: Commit the submodule to the given DuckDB sha | |
| outputs: | |
| sha-after-commit: ${{ steps.git_commit_sha.outputs.commit_sha }} | |
| runs-on: ubuntu-24.04 | |
| permissions: | |
| contents: write | |
| steps: | |
| - name: Checkout DuckDB Python | |
| uses: actions/checkout@v4 | |
| with: | |
| ref: ${{ github.ref }} | |
| fetch-depth: 0 | |
| submodules: true | |
| - name: Checkout DuckDB | |
| run: | | |
| cd external/duckdb | |
| git fetch origin | |
| git checkout ${{ inputs.duckdb-sha }} | |
| - name: Commit and push new submodule ref | |
| if: ${{ inputs.commit-duckdb-sha }} | |
| # see https://github.com/actions/checkout?tab=readme-ov-file#push-a-commit-to-a-pr-using-the-built-in-token | |
| run: | | |
| git config user.name "github-actions[bot]" | |
| git config user.email "41898282+github-actions[bot]@users.noreply.github.com" | |
| git add external/duckdb | |
| if git diff --cached --quiet; then | |
| echo "No changes to commit: submodule ref is unchanged." | |
| else | |
| git commit -m "Update submodule ref" | |
| git push | |
| fi | |
| - name: Get the SHA of the latest commit | |
| id: git_commit_sha | |
| run: | | |
| echo "commit_sha=$( git rev-parse HEAD )" >> $GITHUB_OUTPUT | |
| externally_triggered_build: | |
| name: Build and test releases | |
| needs: commit_submodule | |
| uses: ./.github/workflows/packaging.yml | |
| with: | |
| minimal: false | |
| testsuite: all | |
| git-ref: ${{ needs.commit_submodule.outputs.sha-after-commit }} | |
| duckdb-git-ref: ${{ inputs.duckdb-sha }} | |
| force-version: ${{ inputs.force-version }} | |
| publish_s3: | |
| name: Publish Artifacts to the S3 Staging Bucket | |
| runs-on: ubuntu-latest | |
| needs: [ externally_triggered_build ] | |
| if: ${{ github.repository_owner == 'duckdb' && inputs.publish-packages }} | |
| steps: | |
| - name: Fetch artifacts | |
| uses: actions/download-artifact@v4 | |
| with: | |
| pattern: '{sdist,wheel}*' | |
| path: artifacts/ | |
| merge-multiple: true | |
| - name: Authenticate with AWS | |
| uses: aws-actions/configure-aws-credentials@v4 | |
| with: | |
| aws-region: 'us-east-2' | |
| aws-access-key-id: ${{ secrets.S3_DUCKDB_STAGING_ID }} | |
| aws-secret-access-key: ${{ secrets.S3_DUCKDB_STAGING_KEY }} | |
| - name: Upload artifacts to S3 bucket | |
| # semantics: if a version is forced then we upload into a folder by the version name, otherwise we upload | |
| # into a folder that is named <run id>-<run-attempt>. Only the latter will be discovered be | |
| # upload_to_pypi.yml. | |
| run: | | |
| FOLDER="${{ inputs.force-version != '' && inputs.force-version || format('{0}-{1}', github.run_id, github.run_attempt) }}" | |
| aws s3 cp artifacts s3://duckdb-staging/${{ github.repository }}/${FOLDER}/ --recursive |