-
Notifications
You must be signed in to change notification settings - Fork 38
97 lines (92 loc) · 3.48 KB
/
test.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
name: test
on:
push:
pull_request:
jobs:
test:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v2
with:
ref: ${{ github.event.pull_request.head.sha }}
- name: check urls
uses: urlstechie/urlchecker-action@master
with:
branch: ${{ github.event.pull_request.head.sha }}
subfolder: docs
file_types: .en.md,.md
include_files: '\/([\w-]+)\.(en\.)?md'
print_all: false
retry_count: 2
timeout: 7
force_pass: true # Don't block deployment
save: "output.csv"
verbose: true
# doc paths to exclude from checking
exclude_files: archive/*
# url patterns to exclude
exclude_pattern: '$arch,pagure.io/includedmodule.git,pagure.io/bar.git,.iso,example.com,localhost'
- name: Affected URLs
id: gather
run: |
OUT="$(awk -F, '((NR>1 && $2=="failed") || NR==1 ){print}' output.csv)"
echo 'URLS<<EOF' >> $GITHUB_OUTPUT
echo $OUT >> $GITHUB_OUTPUT
echo 'EOF' >> $GITHUB_OUTPUT
echo "COUNT_U=$(( $(wc -l <<<$OUT) - 1 ))" >> $GITHUB_OUTPUT
outputs:
URLS: ${{ steps.gather.outputs.URLS }}
COUNT_U: ${{ steps.gather.outputs.COUNT_U }}
comment:
name: "Comment on PR"
needs: test
runs-on: ubuntu-latest
steps:
- name: Comment
uses: actions/github-script@v5
env:
URLS: "${{ needs.test.outputs.URLS }}"
COUNT_U: "${{ needs.test.outputs.COUNT_U }}"
with:
github-token: ${{ secrets.GITHUB_TOKEN }}
script: |
const count_u = process.env.COUNT_U.toString();
const commentText = 'Test results for ' + context.payload.pull_request.head.sha + ":\n\nNumber of broken URLs: " + count_u + "\n";
const output = process.env.URLS.toString().trimEnd();
var body = "<details>\n<summary>" + commentText + "</summary>\n\n```csv\n" + output + "\n```\n\n</details>";
const fs = require('fs');
fs.writeFileSync(process.env.GITHUB_STEP_SUMMARY, body);
needNewComment = true;
console.log('Reviewing existing comments...');
for await (const { data: comments } of github.paginate.iterator(
github.rest.issues.listComments,
{
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.payload.pull_request.number,
}
)) {
for (const comment of comments) {
if (comment.user.login === 'github-actions[bot]') {
if (needNewComment && comment.body.includes(commentText)) {
needNewComment = false;
} else {
console.log('Deleting comment: ' + comment.id);
await github.rest.issues.deleteComment({
owner: context.repo.owner,
repo: context.repo.repo,
comment_id: comment.id,
});
}
}
}
}
if (needNewComment) {
console.log('Creating new comment...');
await github.rest.issues.createComment({
owner: context.repo.owner,
repo: context.repo.repo,
issue_number: context.payload.pull_request.number,
body: body,
});
}