-
Notifications
You must be signed in to change notification settings - Fork 0
139 lines (117 loc) · 5.03 KB
/
push_caller_workflow.yml
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
name: ⬆️ Push Caller Workflow to addons
on:
workflow_dispatch:
inputs:
repo_topic:
description: "Filter by topics assigned to repositories"
type: string
required: true
default: "addon"
target_branch:
description: "Branch the workflow should be pushed to"
type: string
required: true
default: "develop"
caller_workflow_name:
description: "Caller workflow name without file extension"
type: string
required: true
dry_run:
description: Run workflow without pushing changes
type: boolean
default: false
env:
# TODO update token to one with enabled workflow permission
GH_TOKEN: ${{ secrets.REPO_CTRL_TOKEN }}
AUTOMATION-REPO: "ops-repo-automation"
jobs:
get-repos:
runs-on: ubuntu-latest
outputs:
repo_matrix: ${{ steps.build-matrix.outputs.matrix }}
steps:
- name: Query caller workflow exists
id: query-caller-workflow
run: |
caller_workflow_files=$(gh api repos/ynput/ops-repo-automation/contents/caller_workflows --jq '.[].name' | sed 's/\.yml$//')
echo "Files: $caller_workflow_files"
$input_name="${{ inputs.target_branch }}"
if echo "$caller_workflow_files" | grep -qw "$input_name"; then
echo "File $input_name exists in the caller workflow directory."
exit 0
fi
echo "::error::File $input_name does not exist in the directory."
exit 1
- name: Build matrix
id: build-matrix
run: |
repo_list=$(gh repo list ynput -L 100 --json name,repositoryTopics | jq -r '[.[] | select(.repositoryTopics != null) | select(any(.repositoryTopics[]; .name == "${{ inputs.repo_topic }}")) | .name]')
echo "$repo_list"
echo 'matrix=$repo_list' >> $GITHUB_OUTPUT
- name: Debug repo list
run: |
echo "${{ steps.build-matrix.outputs.matrix }}"
Update-workflow:
needs:
- get-repos
runs-on: ubuntu-latest
strategy:
fail-fast: false
matrix:
repo_name: ${{ fromJson(needs.get-repos.outputs.repo_matrix) }}
steps:
- name: Test repo exists
run: |
if ! gh repo view "ynput/${{ matrix.repo_name }}" &>/dev/null; then
echo "::error::Repository ynput/${{ matrix.repo_name }} was not found."
exit 1
fi
- name: Check for running workflows
run: |
for i in {1..20}; do
running_workflows=$(gh run list --repo ynput/${{ matrix.repo_name }} -L 100 --status in_progress --json name | jq -r 'map(.name) | join(", ")')
if [[ -n "$running_workflows" ]]; then
echo "::warning::Repo ynput/${{ matrix.repo_name }} currently has running workflows: $running_workflows"
sleep 15
continue
fi
break
done
running_workflows=$(gh run list --repo ynput/${{ matrix.repo_name }} --status in_progress --json name | jq -r 'map(.name) | join(", ")')
if [[ -n "$running_workflows" ]]; then
echo "::error::Repo ynput/${{ matrix.repo_name }} currently has running workflows: $running_workflows"
echo "::error::Repo ynput/${{ matrix.repo_name }} has been running workflows since more then 5 minutes, please check the repo"
exit 1
fi
- name: ⬇️ Checkout ${{ matrix.repo_name }} at ${{ inputs.target_branch }}
uses: actions/checkout@v4
with:
token: ${{ env.GH_TOKEN }}
repository: ynput/${{ matrix.repo_name }}
ref: ${{ inputs.target_branch }}
fetch-depth: 0
- name: Get caller workflow
# TODO update branch
run: |
curl -O https://raw.githubusercontent.com/${{ env.AUTOMATION-REPO }}/push-caller-workflow/caller_workflows/${{ inputs.caller_workflow_name }}.yml
mv ${{ inputs.caller_workflow_name }}.yml ./.github/workflows/${{ inputs.caller_workflow_name }}.yml
- name: Check for changes
id: check_changes
run: |
if [[ `git status --porcelain` ]]; then
echo "push_required=true" >> $GITHUB_OUTPUT
echo "::notice::Changes will be pushed to ${{ matrix.repo_name }} at ${{ inputs.target_branch }}"
else
echo "No changes to push."
echo "push_required=false" >> $GITHUB_OUTPUT
echo "::warning::No changes found, not pushing to ${{ matrix.repo_name }} at ${{ inputs.target_branch }}"
fi
- name: Push changes
if: inputs.dry_run != 'true' && steps.check_changes.outputs.push_required == 'true'
run: |
echo "::error::This should not run"
# git config --global user.name "${{ secrets.CI_USER }}"
# git config --global user.email "${{ secrets.CI_EMAIL }}"
# git add ./.github/workflows/${{ inputs.caller_workflow_name }}.yml
# git commit -m "[Automated] Update ${{ inputs.caller_workflow_name }} caller workflow"
# git push origin ${{ inputs.target_branch }}