-
Notifications
You must be signed in to change notification settings - Fork 26
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
d628c38
commit b2a8aef
Showing
7 changed files
with
151 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1 @@ | ||
node_modules/ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,13 @@ | ||
--- | ||
|
||
name: Report flaky tests | ||
description: Parses log file for flaky tests and adds annotations for them | ||
inputs: | ||
logFile: | ||
description: Log file containing the flaky test logs | ||
required: true | ||
default: 'log/flaky.jsonl' | ||
outputs: | ||
runs: | ||
using: 'node20' | ||
main: 'report_flaky.js' |
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,14 @@ | ||
{ | ||
"name": "report-flaky", | ||
"version": "1.0.0", | ||
"description": "Flaky test reporter action", | ||
"main": "report_flaky.js", | ||
"scripts": { | ||
"test": "echo \"Error: no test specified\" && exit 1" | ||
}, | ||
"author": "", | ||
"license": "MIT", | ||
"dependencies": { | ||
"@actions/core": "^1.10.1" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,26 @@ | ||
// Taken from: https://nodejs.org/api/readline.html#readline_example_read_file_stream_line_by_line | ||
const fs = require('node:fs'); | ||
const readline = require('node:readline'); | ||
|
||
const core = require('@actions/core'); | ||
|
||
const logFilePath = core.getInput('logFile'); | ||
|
||
async function emitAnnotations() { | ||
const fileStream = fs.createReadStream(logFilePath); | ||
|
||
const rl = readline.createInterface({ | ||
input: fileStream, | ||
crlfDelay: Infinity, | ||
}); | ||
// Note: we use the crlfDelay option to recognize all instances of CR LF | ||
// ('\r\n') in input.txt as a single line break. | ||
|
||
for await (const line of rl) { | ||
// each line is expected to be valid JSON | ||
const logRecord = JSON.parse(line); | ||
core.warning(logRecord.msg, {file: logRecord.file, startLine: logRecord.line}); | ||
} | ||
} | ||
|
||
emitAnnotations(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
name: Debug | ||
|
||
# Run this workflow every time a new commit pushed to your repository | ||
on: | ||
push: | ||
|
||
jobs: | ||
debug: | ||
name: Debug | ||
runs-on: ubuntu-latest | ||
|
||
steps: | ||
- uses: actions/checkout@v4 | ||
- run: | | ||
mkdir -p log | ||
echo '{"msg": "Flaky test: test_concurrent_file_uploads", "file": "src/openforms/formio/tests/test_api_fileupload.py", "line": 403}' > log/flaky.jsonl | ||
- run: npm ci | ||
working-directory: .github/actions/report-flaky | ||
|
||
- uses: ./.github/actions/report-flaky |