Release to GitHub, PyPI & Docker #203
Workflow file for this run
This file contains 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
# **what?** | |
# Release workflow provides the following steps: | |
# - checkout the given commit; | |
# - validate version in sources and changelog file for given version; | |
# - bump the version and generate a changelog if needed; | |
# - merge all changes to the target branch if needed; | |
# - run unit and integration tests against given commit; | |
# - build and package that SHA; | |
# - release it to GitHub and PyPI with that specific build; | |
# | |
# **why?** | |
# Ensure an automated and tested release process | |
# | |
# **when?** | |
# This workflow can be run manually on demand or can be called by other workflows | |
name: Release to GitHub and PyPI | |
on: | |
workflow_dispatch: | |
inputs: | |
target_branch: | |
description: "The branch to release from" | |
type: string | |
required: true | |
version_number: | |
description: "The release version number (i.e. 1.0.0b1)" | |
type: string | |
required: true | |
test_run: | |
description: "Test run (Publish release as draft)" | |
type: boolean | |
default: true | |
required: false | |
nightly_release: | |
description: "Nightly release to dev environment" | |
type: boolean | |
default: false | |
required: false | |
workflow_call: | |
inputs: | |
target_branch: | |
description: "The branch to release from" | |
type: string | |
required: true | |
version_number: | |
description: "The release version number (i.e. 1.0.0b1)" | |
type: string | |
required: true | |
test_run: | |
description: "Test run (Publish release as draft)" | |
type: boolean | |
default: true | |
required: false | |
nightly_release: | |
description: "Nightly release to dev environment" | |
type: boolean | |
default: false | |
required: false | |
permissions: | |
contents: write # this is the permission that allows creating a new release | |
defaults: | |
run: | |
shell: bash | |
jobs: | |
job-setup: | |
name: Log Inputs | |
runs-on: ubuntu-latest | |
outputs: | |
starting_sha: ${{ steps.set_sha.outputs.starting_sha }} | |
steps: | |
- name: "[DEBUG] Print Variables" | |
run: | | |
echo Inputs | |
echo The branch to release from: ${{ inputs.target_branch }} | |
echo The release version number: ${{ inputs.version_number }} | |
echo Test run: ${{ inputs.test_run }} | |
echo Nightly release: ${{ inputs.nightly_release }} | |
- name: "Checkout target branch" | |
uses: actions/checkout@v4 | |
with: | |
ref: ${{ inputs.target_branch }} | |
# release-prep.yml really shouldn't take in the sha but since core + all adapters | |
# depend on it now this workaround lets us not input it manually with risk of error. | |
# The changes always get merged into the head so we can't use a specific commit for | |
# releases anyways. | |
- name: "Capture sha" | |
id: set_sha | |
run: | | |
echo "starting_sha=$(git rev-parse HEAD)" >> $GITHUB_OUTPUT | |
bump-version-generate-changelog: | |
name: Bump package version, Generate changelog | |
needs: [job-setup] | |
uses: dbt-labs/dbt-release/.github/workflows/release-prep.yml@pip_install_editable_requirements | |
with: | |
sha: ${{ needs.job-setup.outputs.starting_sha }} | |
version_number: ${{ inputs.version_number }} | |
target_branch: ${{ inputs.target_branch }} | |
env_setup_script_path: "scripts/env-setup.sh" | |
test_run: ${{ inputs.test_run }} | |
nightly_release: ${{ inputs.nightly_release }} | |
secrets: inherit | |
log-outputs-bump-version-generate-changelog: | |
name: "[Log output] Bump package version, Generate changelog" | |
if: ${{ !failure() && !cancelled() }} | |
needs: [bump-version-generate-changelog] | |
runs-on: ubuntu-latest | |
steps: | |
- name: Print variables | |
run: | | |
echo Final SHA : ${{ needs.bump-version-generate-changelog.outputs.final_sha }} | |
echo Changelog path: ${{ needs.bump-version-generate-changelog.outputs.changelog_path }} | |
build-test-package: | |
name: Build, Test, Package | |
if: ${{ !failure() && !cancelled() }} | |
needs: [job-setup, bump-version-generate-changelog] | |
uses: dbt-labs/dbt-release/.github/workflows/build.yml@main | |
with: | |
sha: ${{ needs.bump-version-generate-changelog.outputs.final_sha }} | |
version_number: ${{ inputs.version_number }} | |
changelog_path: ${{ needs.bump-version-generate-changelog.outputs.changelog_path }} | |
build_script_path: "scripts/build-dist.sh" | |
s3_bucket_name: "core-team-artifacts" | |
package_test_command: "dbt --version" | |
test_run: ${{ inputs.test_run }} | |
nightly_release: ${{ inputs.nightly_release }} | |
secrets: | |
AWS_ACCESS_KEY_ID: ${{ secrets.AWS_ACCESS_KEY_ID }} | |
AWS_SECRET_ACCESS_KEY: ${{ secrets.AWS_SECRET_ACCESS_KEY }} | |
github-release: | |
name: GitHub Release | |
if: ${{ !failure() && !cancelled() }} | |
needs: [bump-version-generate-changelog, build-test-package] | |
uses: dbt-labs/dbt-release/.github/workflows/github-release.yml@main | |
with: | |
sha: ${{ needs.bump-version-generate-changelog.outputs.final_sha }} | |
version_number: ${{ inputs.version_number }} | |
changelog_path: ${{ needs.bump-version-generate-changelog.outputs.changelog_path }} | |
test_run: ${{ inputs.test_run }} | |
pypi-release: | |
name: PyPI Release | |
needs: [github-release] | |
uses: dbt-labs/dbt-release/.github/workflows/pypi-release.yml@main | |
with: | |
version_number: ${{ inputs.version_number }} | |
test_run: ${{ inputs.test_run }} | |
secrets: | |
PYPI_API_TOKEN: ${{ secrets.PYPI_API_TOKEN }} | |
TEST_PYPI_API_TOKEN: ${{ secrets.TEST_PYPI_API_TOKEN }} | |
slack-notification: | |
name: Slack Notification | |
if: ${{ failure() && (!inputs.test_run || inputs.nightly_release) }} | |
needs: | |
[ | |
bump-version-generate-changelog, | |
build-test-package, | |
github-release, | |
pypi-release, | |
] | |
uses: dbt-labs/dbt-release/.github/workflows/slack-post-notification.yml@main | |
with: | |
status: "failure" | |
secrets: | |
SLACK_WEBHOOK_URL: ${{ secrets.SLACK_DEV_CORE_ALERTS }} |