-
Notifications
You must be signed in to change notification settings - Fork 43
56 lines (50 loc) · 2.08 KB
/
apisnoop_weekly_updater.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
name: apisnoop weekly updater
on:
workflow_dispatch: {}
schedule:
- cron: "0 12 * * 6"
env:
IMAGE: gcr.io/k8s-staging-apisnoop/snoopdb:v20250115-auditlogger-1.2.13-64-gf795789
jobs:
update:
runs-on: ubuntu-latest
permissions:
contents: write
pull-requests: write
steps:
# Checks-out your repository under $GITHUB_WORKSPACE, so your job can access it
- uses: actions/checkout@v2
- name: configure system
run: |
sudo apt-get update -y
sudo apt-get install -y postgresql-client netcat-openbsd
git config user.name 'github-actions[bot]'
git config user.email 'github-actions[bot]@users.noreply.github.com'
gh auth login --with-token < <(echo ${{ secrets.GITHUB_TOKEN }})
gh auth status
- name: start SnoopDB
run: |
docker run -e POSTGRES_USER=apisnoop -e POSTGRES_DB=apisnoop -e LOAD_K8S_DATA=true --name snoopdb -d -p 5432:5432 $IMAGE
until psql -U apisnoop -d apisnoop -h localhost -c 'select 0;'; do
docker logs --tail=100 snoopdb
sleep 10s
done
- name: run 505_output_coverage_jsons
run: |
cd $(git rev-parse --show-toplevel)
psql -U apisnoop -d apisnoop -h localhost -f ./505_output_coverage_jsons.sql
- name: commit and push if there are changes
run: |
if { git ls-files --others --exclude-standard ; git diff-index --name-only --diff-filter=d HEAD ; } | grep --regexp='[.]json$'; then
echo changes detected
else
exit 0
fi
TIMESTAMP="$(date +%Y-%m-%d-%H-%M)"
NEW_BRANCH="coverage-update-for-${TIMESTAMP}"
git add resources/coverage/*.json
git branch "${NEW_BRANCH}"
git checkout "${NEW_BRANCH}"
git commit -m "chore: update coverage for ${TIMESTAMP}" -m "updates coverage metadata for ${TIMESTAMP}"
git push origin "${NEW_BRANCH}"
gh pr create --title "Update APISnoop coverage ${TIMESTAMP}" --body "updates to coverage for ${TIMESTAMP}"