Release: Bump #1
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
name: "Release: Bump" | ||
on: | ||
workflow_dispatch: | ||
inputs: | ||
force_version_bump: | ||
required: false | ||
default: "" | ||
type: choice | ||
options: | ||
- "" | ||
- patch | ||
- minor | ||
- major | ||
jobs: | ||
UnitTests: | ||
Check failure on line 17 in .github/workflows/release_bump.yml GitHub Actions / Release: BumpInvalid workflow file
|
||
needs: Setup | ||
name: Unit Tests | ||
uses: ./.github/workflows/reuse_python_build.yml | ||
with: | ||
commit: ${{ github.sha }} | ||
secrets: inherit | ||
IntegrationTests: | ||
needs: UnitTests | ||
name: Integration Tests | ||
runs-on: ubuntu-latest | ||
environment: release | ||
permissions: | ||
id-token: write | ||
contents: read | ||
steps: | ||
- uses: actions/checkout@v4 | ||
with: | ||
ref: ${{ github.sha }} | ||
- name: Configure AWS credentials | ||
uses: aws-actions/configure-aws-credentials@v4 | ||
with: | ||
role-to-assume: ${{ secrets.AWS_CODEBUILD_RELEASE_INTEG_ROLE }} | ||
aws-region: us-west-2 | ||
mask-aws-account-id: true | ||
- name: Run CodeBuild | ||
uses: aws-actions/aws-codebuild-run-build@v1 | ||
with: | ||
project-name: deadline-cloud-worker-agent-IntegTest | ||
hide-cloudwatch-logs: true | ||
env-vars-for-codebuild: | | ||
TEST_TYPE | ||
env: | ||
TEST_TYPE: WHEEL | ||
Bump: | ||
needs: IntegrationTests | ||
runs-on: ubuntu-latest | ||
permissions: | ||
contents: write | ||
pull-requests: write | ||
steps: | ||
- name: Checkout | ||
uses: actions/checkout@v4 | ||
with: | ||
ref: release | ||
fetch-depth: 0 | ||
token: ${{ secrets.CI_TOKEN }} | ||
- name: Set up Python | ||
uses: actions/setup-python@v5 | ||
with: | ||
python-version: '3.9' | ||
- name: ConfigureGit | ||
run: | | ||
git config --local user.email "[email protected]" | ||
git config --local user.name "client-software-ci" | ||
- name: MergePushRelease | ||
run: | | ||
git merge --ff-only origin/mainline -v | ||
git push origin release | ||
- name: Bump | ||
run: | | ||
BUMP_ARGS="" | ||
if [[ "${{ inputs.force_version_bump }}" != "" ]]; then | ||
BUMP_ARGS="$BUMP_ARGS --${{ inputs.force_version_bump }}" | ||
fi | ||
# Backup actual changelog to preserve its contents | ||
cp CHANGELOG.md CHANGELOG.bak.md | ||
# Run semantic-release to generate new changelog | ||
pip install --upgrade hatch | ||
hatch env create release | ||
NEXT_SEMVER=$(hatch run release:bump $BUMP_ARGS) | ||
# Grab the new version's changelog and prepend it to the original changelog contents | ||
python .github/scripts/get_latest_changelog.py > NEW_LOG.md | ||
cat NEW_LOG.md CHANGELOG.bak.md > CHANGELOG.md | ||
rm NEW_LOG.md | ||
git checkout -b bump/$NEXT_SEMVER | ||
git add CHANGELOG.md | ||
git commit -sm "chore(release): $NEXT_SEMVER" | ||
echo "NEXT_SEMVER=$NEXT_SEMVER" >> $GITHUB_ENV | ||
{ | ||
echo 'RELEASE_NOTES<<EOF' | ||
python .github/scripts/get_latest_changelog.py | ||
echo EOF | ||
} >> $GITHUB_ENV | ||
- name: PushPR | ||
env: | ||
GH_TOKEN: ${{ secrets.CI_TOKEN }} | ||
run: | | ||
git push -u origin bump/$NEXT_SEMVER | ||
# Needs "Allow GitHub Actions to create and approve pull requests" under Settings > Actions | ||
gh pr create --base release --title "chore(release): $NEXT_SEMVER" --body "$RELEASE_NOTES" |