Release - mock-rock - refs/heads/main #254
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 | |
run-name: 'Release - ${{ inputs.oci-image-name }} - ${{ github.ref }}' | |
on: | |
workflow_dispatch: | |
inputs: | |
oci-image-name: | |
description: 'OCI image to run releases for' | |
required: true | |
image-trigger-cache-key: | |
description: 'Cache key (to fetch image trigger from cache)' | |
required: false | |
type: string | |
external_ref_id: #(1) | |
description: 'Optional ID for unique run detection' | |
required: false | |
type: string | |
default: "default-id" | |
jobs: | |
validate-push-release-request: | |
runs-on: ubuntu-22.04 | |
name: Validate push release request | |
outputs: | |
oci-image-name: ${{ steps.get-image-name.outputs.img-name }} | |
steps: | |
- name: ${{ inputs.external_ref_id }} #(2) | |
run: echo 'Started by ${{ inputs.external_ref_id }}' >> "$GITHUB_STEP_SUMMARY" | |
- uses: actions/checkout@v3 | |
- name: Infer number of image triggers | |
uses: tj-actions/changed-files@v35 | |
id: changed-files | |
with: | |
dir_names: "true" | |
separator: "," | |
files: | | |
oci/*/image.y*ml | |
- name: Fail if more than one image | |
id: get-image-name | |
run: | | |
set -ex | |
img_dir="${{ steps.changed-files.outputs.all_changed_files }}" | |
occurrences="${img_dir//[^,]}" | |
if [ ${#occurrences} -ne 0 ] | |
then | |
echo "ERR: can only release 1 image at a time, but trying to release ${img_dir}" | |
exit 1 | |
fi | |
echo "img-name=$(basename ${img_dir})" >> "$GITHUB_OUTPUT" | |
do-releases: | |
runs-on: ubuntu-22.04 | |
name: Release | |
needs: [validate-push-release-request] | |
outputs: | |
gh-releases-matrix: ${{ steps.release-image.outputs.gh-releases-matrix }} | |
env: | |
IS_PROD: ${{ ! startsWith(inputs.oci-image-name, 'mock-') }} | |
steps: | |
- uses: actions/checkout@v3 | |
- uses: actions/cache/restore@v3 | |
if: ${{ inputs.image-trigger-cache-key != '' }} | |
with: | |
path: oci/${{ inputs.oci-image-name }}/image.yaml | |
key: ${{ inputs.image-trigger-cache-key }} | |
fail-on-cache-miss: true | |
- uses: actions/setup-python@v4 | |
with: | |
python-version: "3.x" | |
- env: | |
ROCKS_DEV_LP_SSH_PRIVATE: ${{ secrets.ROCKS_DEV_LP_SSH_PRIVATE }} | |
ROCKS_DEV_LP_USERNAME: ${{ secrets.ROCKS_DEV_LP_USERNAME }} | |
CPC_BUILD_TOOLS_REPO: git.launchpad.net/~cloudware/cloudware/+git/cpc_build_tools | |
# CPC_BUILD_TOOLS_REPO_REF: 9b716ed8a8ba728d036b54b1bb17a8f49dbda434 | |
SKOPEO_BRANCH: 'v1.9.1' | |
SKOPEO_URL: 'https://github.com/containers/skopeo' | |
run: | | |
./src/image/requirements.sh | |
pip install -r src/image/requirements.txt | |
- name: Get all revisions per track | |
id: get-all-canonical-tags | |
env: | |
OS_USERNAME: ${{ secrets.SWIFT_OS_USERNAME }} | |
OS_TENANT_NAME: ${{ secrets.SWIFT_OS_TENANT_NAME }} | |
OS_PASSWORD: ${{ secrets.SWIFT_OS_PASSWORD }} | |
OS_REGION_NAME: ${{ secrets.SWIFT_OS_REGION_NAME }} | |
OS_STORAGE_URL: ${{ secrets.SWIFT_OS_STORAGE_URL }} | |
IMAGE_NAME: ${{ inputs.oci-image-name }} | |
SWIFT_CONTAINER_NAME: ${{ vars.SWIFT_CONTAINER_NAME }} | |
run: ./src/image/get_canonical_tags_from_swift.sh | |
- name: Do releases from ${{ inputs.oci-image-name }} | |
id: release-image | |
env: | |
# GH has issues with boolean expressions | |
# https://github.com/actions/runner/issues/1483 | |
DOCKER_HUB_CREDS_PSW: ${{ env.IS_PROD == 'true' && secrets.DOCKER_HUB_CREDS_PSW || secrets.DOCKER_HUB_CREDS_PSW_DEV }} | |
DOCKER_HUB_CREDS_USR: ${{ env.IS_PROD == 'true' && secrets.DOCKER_HUB_CREDS_USR || secrets.DOCKER_HUB_CREDS_USR_DEV }} | |
# ACR_CREDS_USR: ${{ env.IS_PROD == 'true' && secrets.ACR_CREDS_USR || secrets.ACR_CREDS_USR_DEV }} | |
# ACR_CREDS_PSW: ${{ env.IS_PROD == 'true' && secrets.ACR_CREDS_PSW || secrets.ACR_CREDS_PSW_DEV }} | |
ECR_CREDS_USR: ${{ env.IS_PROD == 'true' && secrets.ECR_CREDS_USR || secrets.ECR_CREDS_USR_DEV }} | |
ECR_CREDS_PSW: ${{ env.IS_PROD == 'true' && secrets.ECR_CREDS_PSW || secrets.ECR_CREDS_PSW_DEV }} | |
# ECR_LTS_CREDS_USR: ${{ env.IS_PROD == 'true' && secrets.ECR_LTS_CREDS_USR || secrets.ECR_LTS_CREDS_USR_DEV }} | |
# ECR_LTS_CREDS_PSW: ${{ env.IS_PROD == 'true' && secrets.ECR_LTS_CREDS_PSW || secrets.ECR_LTS_CREDS_PSW_DEV }} | |
# ACR_NAMESPACE: ${{ env.IS_PROD == 'true' && 'ubuntu.azurecr.io' || secrets.ACR_NAMESPACE_DEV }} | |
DOCKER_HUB_NAMESPACE: ${{ env.IS_PROD == 'true' && 'docker.io/ubuntu' || secrets.DOCKER_HUB_NAMESPACE_DEV }} | |
ECR_NAMESPACE: ${{ env.IS_PROD == 'true' && 'ubuntu' || secrets.ECR_NAMESPACE_DEV }} | |
# ECR_LTS_NAMESPACE: ${{ env.IS_PROD == 'true' && 'lts' || secrets.ECR_LTS_NAMESPACE_DEV }} | |
PYTHONUNBUFFERED: 1 | |
run: | | |
set -ex | |
echo "Running in production? ${{ env.IS_PROD == 'true' && 'YES' || 'NO' }}" | |
python3 -m src.image.release \ | |
--image-trigger oci/${{ inputs.oci-image-name }}/image.yaml \ | |
--image-name ${{ inputs.oci-image-name }} \ | |
--all-releases oci/${{ inputs.oci-image-name }}/_releases.json \ | |
--all-revision-tags "${{ steps.get-all-canonical-tags.outputs.canonical-tags-file }}" \ | |
--ghcr-repo "${{ github.repository_owner }}/oci-factory" | |
- run: git pull --quiet | |
- name: Commit oci/${{ inputs.oci-image-name }}/_releases.json | |
uses: actions-x/commit@v6 | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
branch: ${{ github.ref }} | |
message: 'ci: automatically update oci/${{ inputs.oci-image-name }}/_releases.json, from ${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ github.run_id }}' | |
files: oci/${{ inputs.oci-image-name }}/_releases.json | |
dispatch-documentation: | |
runs-on: ubuntu-22.04 | |
name: Dispatch documentation | |
needs: [do-releases] | |
steps: | |
- name: Run documentation | |
# Using this actions cause others can have this problem: | |
# https://github.com/convictional/trigger-workflow-and-wait/issues/61 | |
uses: mathze/[email protected] | |
id: run-documentation | |
with: | |
token: ${{ secrets.GITHUB_TOKEN }} | |
ref: ${{ github.ref_name }} | |
fail-on-error: true | |
workflow-name: Documentation.yaml | |
payload: '{ "oci-image-name": "${{ inputs.oci-image-name }}"}' | |
use-marker-step: true | |
trigger-timeout: '30m' | |
run-id: dummy | |
- name: Write step summary | |
run: | | |
url='${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ steps.run-documentation.outputs.run-id }}' | |
echo " - Triggered documentation updates for '${{ inputs.oci-image-name }}' at [${url}](${url})" >> "$GITHUB_STEP_SUMMARY" | |
- name: Enforce docs conclusion | |
if: ${{ steps.run-documentation.outputs.run-conclusion != 'success' }} | |
# The previous step doesn't always raise an error | |
run: | | |
url='${{ github.server_url }}/${{ github.repository }}/actions/runs/${{ steps.run-documentation.outputs.run-id }}' | |
echo "Failed to generate docs for '${{ inputs.oci-image-name }}' at [${url}](${url})." | |
exit 1 | |
do-github-release: | |
runs-on: ubuntu-22.04 | |
name: Github-Release | |
needs: [do-releases] | |
strategy: | |
fail-fast: true | |
matrix: ${{ fromJSON(needs.do-releases.outputs.gh-releases-matrix) }} | |
steps: | |
- uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
ref: ${{ matrix.canonical-tag }} | |
- uses: dev-drprasad/[email protected] | |
# We force delete an existing tag because otherwise we won't get | |
# an email notification and the GH release will have the date from when | |
# it was created the first time (i.e. force-push won't update the date) | |
continue-on-error: true | |
with: | |
tag_name: ${{ matrix.release-name }} | |
github_token: ${{ secrets.GITHUB_TOKEN }} | |
- name: Create Git tag | |
uses: rickstaa/action-create-tag@v1 | |
with: | |
tag: "${{ matrix.release-name }}" | |
message: "release(${{ matrix.name }}): Release image revision ${{ matrix.revision }} to ${{ matrix.channel }}" | |
github_token: ${{ secrets.ROCKSBOT_TOKEN }} | |
commit_sha: ${{ matrix.canonical-tag }} | |
force_push_tag: true | |
- uses: "softprops/action-gh-release@v1" | |
with: | |
name: "${{ matrix.release-name }}" | |
tag_name: "${{ matrix.release-name }}" | |
token: "${{ secrets.ROCKSBOT_TOKEN }}" |