pulumi/.github/workflows/on-push.yml

85 lines
2.4 KiB
YAML

name: On Push
permissions:
# To push the tag
contents: write
on:
push:
branches:
- 'master'
jobs:
info:
name: info
uses: ./.github/workflows/ci-info.yml
permissions:
contents: read
with:
ref: ${{ github.ref }}
is-snapshot: false
secrets: inherit
dev-release:
name: dev-release
needs: [info]
uses: ./.github/workflows/ci-dev-release.yml
permissions:
contents: write
# To sign artifacts.
id-token: write
with:
ref: ${{ github.ref }}
version: ${{ needs.info.outputs.version }}
secrets: inherit
update-dev-version:
name: update-dev-version
needs: [dev-release, info]
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
with:
ref: ${{ github.ref }}
- name: Install Pulumictl
uses: jaxxstorm/action-install-gh-release@v1.11.0
env:
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
with:
repo: pulumi/pulumictl
tag: v0.0.46
cache: enable
- name: Git describe
id: ghd
uses: proudust/gh-describe@v1
- name: Dispatch event to docs repo
env:
GITHUB_TOKEN: ${{ secrets.PULUMI_BOT_TOKEN }}
# Always prefix the short_sha with a letter to ensure it's a valid semver prerelease,
# see https://github.com/pulumi/pulumi/issues/15471 for context.
run: |
if [ "$(git ls-remote https://github.com/pulumi/pulumi HEAD | cut -f 1)" = "${{ github.sha }}" ]; then
short_sha="x${{ steps.ghd.outputs.short-sha }}"
version="${{ needs.info.outputs.version }}"
version="${version#v}-alpha.${short_sha}"
pulumictl dispatch -c pulumi-cli-dev-version -r pulumi/docs dev_version="$version"
else
echo "Not updating latest version as there has been a new push to the main branch"
fi
tag-pkg:
name: tag-pkg
runs-on: ubuntu-latest
steps:
- name: Checkout
uses: actions/checkout@v4
- name: Tag and push pkg version if necessary
run: |
title=$(git show --pretty=format:%s -s HEAD)
if [[ $title == "Changelog and go.mod updates for"* ]]; then
pkg_version="${title#*updates for }"
pkg_version="${pkg_version% \(*}"
git tag "pkg/${pkg_version}"
git push origin "pkg/${pkg_version}"
fi