Skip to content

Release 1.7.12 to GitHub, PyPI & Docker #224

Release 1.7.12 to GitHub, PyPI & Docker

Release 1.7.12 to GitHub, PyPI & Docker #224

Workflow file for this run

# **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;
# - release it to Docker
#
# **why?**
# Ensure an automated and tested release processs
#
# **when?**
# This workflow can be run manually on demand or can be called by other workflows
name: "Release to GitHub, PyPI & Docker"
run-name: "Release ${{ inputs.version_number }} to GitHub, PyPI & Docker"
on:
workflow_dispatch:
inputs:
target_branch:
description: "The branch to release from"
type: string
required: true
default: "er/playground"
version_number:
description: "The release version number (i.e. 1.0.0b1)"
type: string
required: true
default: "1.7.12"
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@main
# 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 }}
determine-docker-package:
# dbt-postgres exists within dbt-core for versions 1.7 and earlier but is a separate package for 1.8 and later.
# determine if we need to release dbt-core or both dbt-core and dbt-postgres
name: Determine Docker Package
runs-on: ubuntu-latest
# needs: [pypi-release]
outputs:
matrix: ${{ steps.determine-docker-package.outputs.matrix }}
steps:
- name: "Audit Version And Parse Into Parts"
id: semver
uses: dbt-labs/actions/[email protected]
with:
version: ${{ inputs.version_number }}
- name: "Determine Packages to Release"
id: determine-docker-package
run: |
if [ ${{ steps.semver.outputs.minor }} -ge 8 ]; then
json_output={\"package\":[\"dbt-core\"]}
else
json_output={\"package\":[\"dbt-core\",\"dbt-postgres\"]}
fi
echo "matrix=$json_output" >> $GITHUB_OUTPUT
docker-release:
name: "Docker Release for ${{ matrix.package }}"
needs: [determine-docker-package]
strategy:
matrix: ${{fromJson(needs.determine-docker-package.outputs.matrix)}}
runs-on: ubuntu-latest
steps:
- name: Print variables
run: |
package : ${{ matrix.package }}
# permissions:
# packages: write
# uses: dbt-labs/dbt-release/.github/workflows/release-docker.yml@main
# with:
# package: ${{ matrix.package }}
# version_number: ${{ inputs.version_number }}
# test_run: ${{ inputs.test_run }}
# 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,
# docker-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 }}