-
Notifications
You must be signed in to change notification settings - Fork 93
71 lines (66 loc) · 2.51 KB
/
e2e-infra-cleanup.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
name: e2e-infra-cleanup
on:
workflow_dispatch:
inputs:
cleanup_interval_hours:
description: Cleanup interval in hours
required: true
default: "24"
schedule:
- cron: "0 * * * *"
concurrency: e2e-infra-cleanup
env:
AWS_DEFAULT_REGION: us-east-1
AWS_ACCESS_KEY_ID: ${{ secrets.E2E_TESTIM_AWS_ACCESS_KEY_ID }}
AWS_SECRET_ACCESS_KEY: ${{ secrets.E2E_TESTIM_AWS_SECRET_ACCESS_KEY }}
CLEANUP_INTERVAL_HOURS: ${{ github.event.inputs.cleanup_interval_hours || '24' }}
jobs:
find-expired-workspaces:
runs-on: ubuntu-latest
defaults:
run:
working-directory: automation/jumpbox
outputs:
workspaces: ${{ steps.get-workspaces.outputs.workspaces }}
count: ${{ steps.get-workspaces.outputs.count }}
steps:
- name: Checkout
uses: actions/checkout@v3
with:
repository: replicatedhq/kots-regression-automation
token: ${{ secrets.E2E_GH_PAT }}
path: automation
ref: main
- name: Setup Terraform
uses: hashicorp/setup-terraform@v2
with:
terraform_wrapper: false
- name: Initialize terraform
run: terraform init
- name: Get automation workspaces
id: get-workspaces
run: |
mapfile -t WORKSPACES < <(terraform workspace list | grep "automation-")
declare -a EXPIRED_WORKSPACES
for TF_WORKSPACE in "${WORKSPACES[@]}"; do
COMPLETION=$(date -d "$(terraform output -no-color -raw completion_timestamp)" +%s) || continue
[ $(($(date +%s) - COMPLETION)) -gt $((60 * 60 * CLEANUP_INTERVAL_HOURS)) ] && EXPIRED_WORKSPACES+=("${TF_WORKSPACE}")
done
echo "workspaces=$(printf '%s\n' "${EXPIRED_WORKSPACES[@]}" | head -c -1 | jq -R . | jq -sc .)" >> "$GITHUB_OUTPUT"
echo "count=$(printf '%s\n' "${EXPIRED_WORKSPACES[@]}" | head -c -1 | jq -R . | jq -sc '. | length')" >> "$GITHUB_OUTPUT"
cleanup-expired-workspaces:
needs: find-expired-workspaces
if: ${{ needs.find-expired-workspaces.outputs.count > 0 }}
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
workspace: ${{ fromJSON(needs.find-expired-workspaces.outputs.workspaces) }}
steps:
- name: Trigger workspace cleanup
uses: peter-evans/repository-dispatch@v2
with:
token: ${{ secrets.E2E_GH_PAT }}
repository: replicatedhq/kots
event-type: e2e-workspace-cleanup
client-payload: '{"workspace": "${{ matrix.workspace }}"}'