Skip to content

chore: runtimem syncroot workflow-engine only tt02 (#18282) #137

chore: runtimem syncroot workflow-engine only tt02 (#18282)

chore: runtimem syncroot workflow-engine only tt02 (#18282) #137

name: Runtime - deploy syncroot
on:
push:
branches:
- main
paths:
- infra/runtime/syncroot/**
- .github/workflows/deploy-runtime-syncroot.yaml
workflow_dispatch:
inputs:
environments:
description: "Runtime environments to tag. Comma-separated (e.g. at_ring1,at_ring2)."
required: false
default: "at_ring1"
permissions:
id-token: write
contents: read
actions: write
jobs:
get-short-sha:
uses: ./.github/workflows/template-short-sha.yaml
construct-rings-array:
uses: ./.github/workflows/template-runtime-construct-environments.yaml
with:
inputs: ${{ toJSON(github.event.inputs) }}
push-syncroot-artifact:
name: Push syncroot as OCI artifact
needs: get-short-sha
runs-on: ubuntu-latest
environment: dev
permissions:
id-token: write # Require write permission to Fetch an OIDC token.
outputs:
short-sha: ${{ needs.get-short-sha.outputs.short-sha }}
defaults:
run:
working-directory: ./infra/runtime
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6
with:
fetch-depth: 0 # Shallow clone
- name: az login
uses: azure/login@a457da9ea143d694b1b9c7c869ebb04ebe844ef5 # v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID_FC }}
tenant-id: ${{ secrets.AZURE_TENANT_ID_FC }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID_FC }}
- name: az acr login
run: az acr login --name altinncr
- name: flux install
uses: fluxcd/flux2/action@bfa461ed2153ae5e0cca6bce08e0845268fb3088 # v2.8.2
- name: push artifact
run: |
cd syncroot/
flux push artifact oci://altinncr.azurecr.io/studio-apps/syncroot:${{ needs.get-short-sha.outputs.short-sha }} \
--provider=generic \
--reproducible \
--path="." \
--source="$(git config --get remote.origin.url)" \
--revision="$(git branch --show-current)/$(git rev-parse HEAD)"
tag-syncroot:
name: Tag syncroot
needs: [push-syncroot-artifact, construct-rings-array]
runs-on: ubuntu-latest
environment: ${{ matrix.environment }}
permissions:
id-token: write # Require write permission to Fetch an OIDC token.
strategy:
matrix:
include: ${{ fromJson(needs.construct-rings-array.outputs.result) }}
steps:
- uses: actions/checkout@de0fac2e4500dabe0009e67214ff5f5447ce83dd # v6
with:
fetch-depth: 0 # Shallow clone
- name: az login
uses: azure/login@a457da9ea143d694b1b9c7c869ebb04ebe844ef5 # v2
with:
client-id: ${{ secrets.AZURE_CLIENT_ID_FC }}
tenant-id: ${{ secrets.AZURE_TENANT_ID_FC }}
subscription-id: ${{ secrets.AZURE_SUBSCRIPTION_ID_FC }}
- name: az acr login
run: az acr login --name altinncr
- name: flux install
uses: fluxcd/flux2/action@bfa461ed2153ae5e0cca6bce08e0845268fb3088 # v2.8.2
- name: tag artifact
run: |
flux tag artifact oci://altinncr.azurecr.io/studio-apps/syncroot:${{ needs.push-syncroot-artifact.outputs.short-sha }} \
--tag ${{ matrix.ring }}