Various CTRF utilities available programatically and by command line
⭐ If you find this project useful, please consider following the CTRF organisation and giving this repository a star ⭐
It means a lot to us and helps us grow this open source library.
Name | Details |
---|---|
merge |
Merge multiple CTRF reports into a single report. |
flaky |
Output flaky test name and retries. |
This might be useful if you need a single report, but your chosen reporter generates multiple reports through design, parallelisation or otherwise.
To merge CTRF reports in a specified directory, use the following command:
npx ctrf merge <directory>
Replace directory
with the path to the directory containing the CTRF reports you want to merge.
-o, --output filename
: Output file name for the merged report. Default is ctrf-report.json.
npx ctrf merge <directory> --output my-merged-report.json
-d, --output-dir directory
: Output directory for the merged report. Default is the same directory as the input reports.
npx ctrf merge <directory> --output-dir /path/to/output
-k, --keep-reports: Keep existing reports after merging. By default, the original reports will be deleted after merging.
npx ctrf merge <directory> --keep-reports
The flaky command is useful for identifying tests marked as flaky in your CTRF report. Flaky tests are tests that pass or fail inconsistently and may require special attention or retries to determine their reliability.
Usage To output flaky tests, use the following command:
npx ctrf flaky <file-path>
Replace with the path to the CTRF report file you want to analyze.
The command will output the names of the flaky tests and the number of retries each test has undergone. For example:
Processing report: reports/sample-report.json
Found 1 flaky test(s) in reports/sample-report.json:
- Test Name: Test 1, Retries: 2
npm install ctrf
The following programmatic methods are available:
mergeReports
- This method merges multiple CTRF reports into a single report.
readSingleReport
- Reads and parses a single CTRF report file from a specified file path.
readReportsFromDirectory
- Reads all CTRF report files from a given directory.
readReportsFromGlobPattern
- Reads all CTRF report files from a given glob pattern.
CTRF is a universal JSON test report schema that addresses the lack of a standardized format for JSON test reports.
Consistency Across Tools: Different testing tools and frameworks often produce reports in varied formats. CTRF ensures a uniform structure, making it easier to understand and compare reports, regardless of the testing tool used.
Language and Framework Agnostic: It provides a universal reporting schema that works seamlessly with any programming language and testing framework.
Facilitates Better Analysis: With a standardized format, programatically analyzing test outcomes across multiple platforms becomes more straightforward.
If you find this project useful, consider giving it a GitHub star ⭐ It means a lot to us.