Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ci: ensure the check-for-changes checks previous deployed version #1346

Merged
merged 35 commits into from
Nov 1, 2024
Merged
Show file tree
Hide file tree
Changes from 30 commits
Commits
Show all changes
35 commits
Select commit Hold shift + click to select a range
4cf5f6a
ci: ensure the diff checks previous deployed version
arealmaas Oct 22, 2024
a605936
ci: ensure the check-for-changes checks previous deployed version
arealmaas Oct 24, 2024
8400999
cleanup
arealmaas Oct 24, 2024
f3c4172
cleanup
arealmaas Oct 25, 2024
8e76b7b
test workflow
arealmaas Oct 25, 2024
1dcb05d
cleanup
arealmaas Oct 25, 2024
5f938c8
cleanup
arealmaas Oct 25, 2024
26f443d
cleanup
arealmaas Oct 25, 2024
518bd22
cleanup
arealmaas Oct 25, 2024
bc03c46
cleanup
arealmaas Oct 25, 2024
6863322
cleanup
arealmaas Oct 25, 2024
e94ce27
cleanup
arealmaas Oct 25, 2024
614b213
cleanup
arealmaas Oct 25, 2024
3db5236
cleanup
arealmaas Oct 25, 2024
e24d464
cleanup
arealmaas Oct 25, 2024
dad286b
cleanup
arealmaas Oct 25, 2024
20c2cba
cleanup
arealmaas Oct 25, 2024
7ca9cc6
cleanup
arealmaas Oct 25, 2024
21260df
cleanup
arealmaas Oct 25, 2024
9cc5115
cleanup
arealmaas Oct 25, 2024
6bd85bd
cleanup
arealmaas Oct 25, 2024
fc2d532
cleanup
arealmaas Oct 25, 2024
92f822a
fo sho
arealmaas Oct 29, 2024
48bd411
cleanup
arealmaas Oct 29, 2024
b79ceb6
renames and improvements
arealmaas Oct 29, 2024
b53e525
cleanup
arealmaas Oct 29, 2024
2a7cf01
cleanup
arealmaas Oct 29, 2024
54b22fc
cleanup
arealmaas Oct 29, 2024
8151ff3
revert the pull-request workflow
arealmaas Oct 29, 2024
216c120
cleanup
arealmaas Oct 29, 2024
f76e637
renames
arealmaas Oct 29, 2024
1b3f40c
Merge branch 'main' into ci/ensure-proper-diff-in-check-changes-2
arealmaas Oct 29, 2024
f114ca3
Merge branch 'main' into ci/ensure-proper-diff-in-check-changes-2
arealmaas Oct 31, 2024
508e03c
Update .github/workflows/ci-cd-yt01.yml
arealmaas Oct 31, 2024
33a986b
Update .github/workflows/ci-cd-yt01.yml
arealmaas Oct 31, 2024
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
37 changes: 36 additions & 1 deletion .github/workflows/ci-cd-prod.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,21 @@ concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}

jobs:
# Get changed files between previous tag and current tag: https://github.com/marketplace/actions/changed-files
get-versions-from-github:
name: Get Latest Deployed Version Info from GitHub
uses: ./.github/workflows/workflow-get-latest-deployed-version-info-from-github.yml
with:
environment: prod
secrets:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}

check-for-changes:
name: Check for changes
needs: [get-versions-from-github]
uses: ./.github/workflows/workflow-check-for-changes.yml
with:
infra_base_sha: ${{ needs.get-versions-from-github.outputs.infra_version_sha }}
apps_base_sha: ${{ needs.get-versions-from-github.outputs.apps_version_sha }}

get-current-version:
name: Get current version
Expand Down Expand Up @@ -56,6 +67,18 @@ jobs:
region: norwayeast
version: ${{ needs.get-current-version.outputs.version }}

store-infra-version:
name: Store Latest Deployed Infra Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-infra, get-current-version]
if: ${{ needs.deploy-infra.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed infra version
run: |
gh variable set LATEST_DEPLOYED_INFRA_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env prod --repo ${{ github.repository }}
arealmaas marked this conversation as resolved.
Show resolved Hide resolved

dry-run-deploy-apps:
name: Dry run deploy apps to prod
needs:
Expand Down Expand Up @@ -104,6 +127,18 @@ jobs:
version: ${{ needs.get-current-version.outputs.version }}
runMigration: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasMigrationChanges == 'true' }}

store-apps-version:
name: Store Latest Deployed Apps Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-apps, get-current-version]
if: ${{ needs.deploy-apps.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed apps version
run: |
gh variable set LATEST_DEPLOYED_APPS_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env prod --repo ${{ github.repository }}
arealmaas marked this conversation as resolved.
Show resolved Hide resolved

deploy-slack-notifier:
name: Deploy slack notifier (prod)
needs: [check-for-changes]
Expand Down
61 changes: 47 additions & 14 deletions .github/workflows/ci-cd-staging.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,26 +10,26 @@ concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}

jobs:
# Get changed files between previous tag and current tag: https://github.com/marketplace/actions/changed-files
get-versions-from-github:
name: Get Latest Deployed Version Info from GitHub
uses: ./.github/workflows/workflow-get-latest-deployed-version-info-from-github.yml
with:
environment: staging
secrets:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}

check-for-changes:
name: Check for changes
needs: [get-versions-from-github]
uses: ./.github/workflows/workflow-check-for-changes.yml
with:
infra_base_sha: ${{ needs.get-versions-from-github.outputs.infra_version_sha }}
apps_base_sha: ${{ needs.get-versions-from-github.outputs.apps_version_sha }}

get-current-version:
name: Get current version
uses: ./.github/workflows/workflow-get-current-version.yml

publish:
name: Build and publish docker images
uses: ./.github/workflows/workflow-publish.yml
if: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasBackendChanges == 'true' }}
needs: [get-current-version, check-for-changes]
secrets:
GCR_PASSWORD: ${{ secrets.GITHUB_TOKEN }}
with:
dockerImageBaseName: ghcr.io/digdir/dialogporten-
version: ${{ needs.get-current-version.outputs.version }}

deploy-infra:
name: Deploy infra to staging
if: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasAzureChanges == 'true' }}
Expand All @@ -48,18 +48,39 @@ jobs:
region: norwayeast
version: ${{ needs.get-current-version.outputs.version }}

store-infra-version:
name: Store Latest Deployed Infra Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-infra, get-current-version]
if: ${{ needs.deploy-infra.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed infra version
run: |
gh variable set LATEST_DEPLOYED_INFRA_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env staging --repo ${{ github.repository }}

publish:
name: Build and publish docker images
uses: ./.github/workflows/workflow-publish.yml
if: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasBackendChanges == 'true' }}
needs: [get-current-version, check-for-changes]
secrets:
GCR_PASSWORD: ${{ secrets.GITHUB_TOKEN }}
with:
dockerImageBaseName: ghcr.io/digdir/dialogporten-
version: ${{ needs.get-current-version.outputs.version }}

deploy-apps:
name: Deploy apps to staging
needs:
[get-current-version, check-for-changes, deploy-infra, publish]
# we want deployment of apps to be dependent on deployment of infrastructure, but if infrastructure is skipped, we still want to deploy the apps
if: ${{ always() && !failure() && !cancelled() && (github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasBackendChanges == 'true') }}
uses: ./.github/workflows/workflow-deploy-apps.yml
secrets:
AZURE_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
AZURE_TENANT_ID: ${{ secrets.AZURE_TENANT_ID }}
AZURE_SUBSCRIPTION_ID: ${{ secrets.AZURE_SUBSCRIPTION_ID }}
# todo: consider resolving these in another way since they are created in the infra-step
AZURE_RESOURCE_GROUP_NAME: ${{ secrets.AZURE_RESOURCE_GROUP_NAME }}
AZURE_ENVIRONMENT_KEY_VAULT_NAME: ${{ secrets.AZURE_ENVIRONMENT_KEY_VAULT_NAME }}
AZURE_CONTAINER_APP_ENVIRONMENT_NAME: ${{ secrets.AZURE_CONTAINER_APP_ENVIRONMENT_NAME }}
Expand All @@ -72,6 +93,18 @@ jobs:
version: ${{ needs.get-current-version.outputs.version }}
runMigration: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasMigrationChanges == 'true' }}

store-apps-version:
name: Store Latest Deployed Apps Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-apps, get-current-version]
if: ${{ needs.deploy-apps.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed apps version
run: |
gh variable set LATEST_DEPLOYED_APPS_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env staging

deploy-slack-notifier:
name: Deploy slack notifier (staging)
needs: [check-for-changes]
Expand Down
37 changes: 36 additions & 1 deletion .github/workflows/ci-cd-yt01.yml
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,21 @@ concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}

jobs:
# Get changed files between previous tag and current tag: https://github.com/marketplace/actions/changed-files
get-versions-from-github:
name: Get Latest Deployed Version Info from GitHub
uses: ./.github/workflows/workflow-get-latest-deployed-version-info-from-github.yml
with:
environment: yt01
secrets:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}

arealmaas marked this conversation as resolved.
Show resolved Hide resolved
check-for-changes:
name: Check for changes
needs: [get-versions-from-github]
uses: ./.github/workflows/workflow-check-for-changes.yml
with:
infra_base_sha: ${{ needs.get-versions-from-github.outputs.infra_version_sha }}
apps_base_sha: ${{ needs.get-versions-from-github.outputs.apps_version_sha }}

get-current-version:
name: Get current version
Expand Down Expand Up @@ -48,6 +59,18 @@ jobs:
region: norwayeast
version: ${{ needs.get-current-version.outputs.version }}

store-infra-version:
name: Store Latest Deployed Infra Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-infra, get-current-version]
if: ${{ needs.deploy-infra.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed infra version
run: |
gh variable set LATEST_DEPLOYED_INFRA_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env yt01 --repo ${{ github.repository }}

arealmaas marked this conversation as resolved.
Show resolved Hide resolved
deploy-apps:
name: Deploy apps to yt01
needs:
Expand All @@ -72,6 +95,18 @@ jobs:
version: ${{ needs.get-current-version.outputs.version }}
runMigration: ${{ github.event_name == 'workflow_dispatch' || needs.check-for-changes.outputs.hasMigrationChanges == 'true' }}

store-apps-version:
name: Store Latest Deployed Apps Version as GitHub Variable
runs-on: ubuntu-latest
needs: [deploy-apps, get-current-version]
if: ${{ needs.deploy-apps.result == 'success' }}
env:
GH_TOKEN: ${{ secrets.GITHUB_TOKEN }}
steps:
- name: Set GitHub variable for latest deployed apps version
run: |
gh variable set LATEST_DEPLOYED_APPS_VERSION --body "${{ needs.get-current-version.outputs.version }}" --env yt01 --repo ${{ github.repository }}

arealmaas marked this conversation as resolved.
Show resolved Hide resolved
deploy-slack-notifier:
name: Deploy slack notifier (yt01)
needs: [check-for-changes]
Expand Down
6 changes: 1 addition & 5 deletions .github/workflows/dispatch-apps.yml
Original file line number Diff line number Diff line change
Expand Up @@ -27,6 +27,7 @@ concurrency:
group: ${{ github.workflow }}-${{ github.ref_name }}-${{ inputs.environment }}

jobs:

generate-git-short-sha:
name: Generate git short sha
uses: ./.github/workflows/workflow-generate-git-short-sha.yml
Expand All @@ -35,16 +36,11 @@ jobs:
name: Get current version
uses: ./.github/workflows/workflow-get-current-version.yml

check-for-changes:
name: Check for changes
uses: ./.github/workflows/workflow-check-for-changes.yml

deploy-apps:
name: Deploy apps to ${{ inputs.environment }}
needs:
- generate-git-short-sha
- get-current-version
- check-for-changes
uses: ./.github/workflows/workflow-deploy-apps.yml
secrets:
AZURE_CLIENT_ID: ${{ secrets.AZURE_CLIENT_ID }}
Expand Down
42 changes: 30 additions & 12 deletions .github/workflows/workflow-check-for-changes.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,17 @@ name: "Check for file changes"

on:
workflow_call:
inputs:
infra_base_sha:
description: "Base SHA for infrastructure changes"
required: false
default: ''
type: string
apps_base_sha:
description: "Base SHA for application changes"
required: false
default: ''
type: string
outputs:
hasAzureChanges:
description: "Azure related files changed"
Expand All @@ -21,42 +32,49 @@ on:
hasMigrationChanges:
description: "Migration related files changed"
value: ${{ jobs.check-for-changes.outputs.hasMigrationChanges }}

jobs:
check-for-changes:
name: Filter
runs-on: ubuntu-latest
outputs:
hasBackendChanges: ${{ steps.filter.outputs.backend_any_modified == 'true' }}
hasTestChanges: ${{ steps.filter.outputs.tests_any_modified == 'true' }}
hasBackendChanges: ${{ steps.filter-backend.outputs.backend_any_modified == 'true' }}
hasAzureChanges: ${{ steps.filter.outputs.azure_any_modified == 'true' }}
hasTestChanges: ${{ steps.filter-backend.outputs.tests_any_modified == 'true' }}
hasSlackNotifierChanges: ${{ steps.filter.outputs.slackNotifier_any_modified == 'true'}}
hasSchemaChanges: ${{ steps.filter.outputs.schema_any_modified == 'true'}}
hasMigrationChanges: ${{ steps.filter.outputs.migration_any_modified == 'true'}}
hasSchemaChanges: ${{ steps.filter-backend.outputs.schema_any_modified == 'true'}}
hasMigrationChanges: ${{ steps.filter-backend.outputs.migration_any_modified == 'true'}}
steps:
- name: Checkout
uses: actions/checkout@v4
with:
# fetch-depth needs to be 0 in cases where we want to fetch changes since previous tag for example
fetch-depth: 0

- uses: tj-actions/changed-files@v45
id: filter
with:
base_sha: ${{ inputs.infra_base_sha }}
files_yaml: |
backend:
- '.github/**/*'
- 'src/**/*'
- '.azure/applications/**/*'
- '.azure/modules/containerApp/**/*'
tests:
- 'tests/**/*'
azure:
- '.github/**/*'
- '.azure/infrastructure/**/*'
- '.azure/modules/**/*'
slackNotifier:
- '.github/**/*'
- 'src/Digdir.Tool.Dialogporten.SlackNotifier/**/*'

- uses: tj-actions/changed-files@v45
id: filter-backend
with:
base_sha: ${{ inputs.apps_base_sha }}
files_yaml: |
backend:
- '.github/**/*'
- 'src/**/*'
- '.azure/applications/**/*'
- '.azure/modules/containerApp/**/*'
tests:
arealmaas marked this conversation as resolved.
Show resolved Hide resolved
- 'tests/**/*'
schema:
- 'docs/schema/V1/**/*'
migration:
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
name: Get Latest Deployed Version Info from GitHub

on:
workflow_call:
inputs:
environment:
description: "Environment to get latest deployed versions for (e.g., staging, prod, yt01)"
required: true
type: string
secrets:
GH_TOKEN:
required: true
outputs:
infra_version_sha:
description: "SHA of the latest deployed infrastructure version"
value: ${{ jobs.get-versions.outputs.infra_version_sha }}
apps_version_sha:
description: "SHA of the latest deployed applications version"
value: ${{ jobs.get-versions.outputs.apps_version_sha }}

jobs:
get-versions:
name: Get Latest Deployed Versions from GitHub Variables
runs-on: ubuntu-latest
environment: ${{ inputs.environment }}
env:
GH_TOKEN: ${{ secrets.GH_TOKEN }}
outputs:
infra_version_sha: ${{ steps.get-infra-sha.outputs.sha }}
apps_version_sha: ${{ steps.get-apps-sha.outputs.sha }}
steps:
- name: Checkout repository
uses: actions/checkout@v4
with:
fetch-depth: 0

- name: Get Infra SHA
id: get-infra-sha
if: vars.LATEST_DEPLOYED_INFRA_VERSION != ''
run: |
SHA=$(git rev-list -n 1 v${{ vars.LATEST_DEPLOYED_INFRA_VERSION }})
echo "sha=$SHA" >> $GITHUB_OUTPUT

arealmaas marked this conversation as resolved.
Show resolved Hide resolved
- name: Get Apps SHA
id: get-apps-sha
if: vars.LATEST_DEPLOYED_APPS_VERSION != ''
run: |
SHA=$(git rev-list -n 1 v${{ vars.LATEST_DEPLOYED_APPS_VERSION }})
echo "sha=$SHA" >> $GITHUB_OUTPUT
arealmaas marked this conversation as resolved.
Show resolved Hide resolved
Loading