mirror of
https://github.com/dorny/test-reporter.git
synced 2025-12-16 06:17:10 +01:00
Compare commits
No commits in common. "aef3d726a667eb6e58a1510ca60e0763a924f17d" and "e2f0ff63390c1e595b4d343f81b365138ce433b5" have entirely different histories.
aef3d726a6
...
e2f0ff6339
14 changed files with 406 additions and 1010 deletions
17
README.md
17
README.md
|
|
@ -19,7 +19,6 @@ This [Github Action](https://github.com/features/actions) displays test results
|
||||||
- Go / [go test](https://pkg.go.dev/testing)
|
- Go / [go test](https://pkg.go.dev/testing)
|
||||||
- Java / [JUnit](https://junit.org/)
|
- Java / [JUnit](https://junit.org/)
|
||||||
- JavaScript / [JEST](https://jestjs.io/) / [Mocha](https://mochajs.org/)
|
- JavaScript / [JEST](https://jestjs.io/) / [Mocha](https://mochajs.org/)
|
||||||
- Python / [pytest](https://docs.pytest.org/en/stable/) / [unittest](https://docs.python.org/3/library/unittest.html)
|
|
||||||
- Swift / xUnit
|
- Swift / xUnit
|
||||||
|
|
||||||
For more information see [Supported formats](#supported-formats) section.
|
For more information see [Supported formats](#supported-formats) section.
|
||||||
|
|
@ -146,9 +145,7 @@ jobs:
|
||||||
# java-junit
|
# java-junit
|
||||||
# jest-junit
|
# jest-junit
|
||||||
# mocha-json
|
# mocha-json
|
||||||
# python-xunit
|
|
||||||
# rspec-json
|
# rspec-json
|
||||||
# swift-xunit
|
|
||||||
reporter: ''
|
reporter: ''
|
||||||
|
|
||||||
# Allows you to generate only the summary.
|
# Allows you to generate only the summary.
|
||||||
|
|
@ -352,20 +349,6 @@ Before version [v9.1.0](https://github.com/mochajs/mocha/releases/tag/v9.1.0), M
|
||||||
Please update Mocha to version [v9.1.0](https://github.com/mochajs/mocha/releases/tag/v9.1.0) or above if you encounter this issue.
|
Please update Mocha to version [v9.1.0](https://github.com/mochajs/mocha/releases/tag/v9.1.0) or above if you encounter this issue.
|
||||||
</details>
|
</details>
|
||||||
|
|
||||||
<details>
|
|
||||||
<summary>python-xunit (Experimental)</summary>
|
|
||||||
|
|
||||||
Support for Python test results in xUnit format is experimental - should work but it was not extensively tested.
|
|
||||||
|
|
||||||
For **pytest** support, configure [JUnit XML output](https://docs.pytest.org/en/stable/how-to/output.html#creating-junitxml-format-files) and run with the `--junit-xml` option, which also lets you specify the output path for test results.
|
|
||||||
|
|
||||||
```shell
|
|
||||||
pytest --junit-xml=test-report.xml
|
|
||||||
```
|
|
||||||
|
|
||||||
For **unittest** support, use a test runner that outputs the JUnit report format, such as [unittest-xml-reporting](https://pypi.org/project/unittest-xml-reporting/).
|
|
||||||
</details>
|
|
||||||
|
|
||||||
<details>
|
<details>
|
||||||
<summary>swift-xunit (Experimental)</summary>
|
<summary>swift-xunit (Experimental)</summary>
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,26 +0,0 @@
|
||||||

|
|
||||||
|Report|Passed|Failed|Skipped|Time|
|
|
||||||
|:---|---:|---:|---:|---:|
|
|
||||||
|[fixtures/python-xunit-pytest.xml](#user-content-r0)|6 ✅|2 ❌|2 ⚪|19ms|
|
|
||||||
## ❌ <a id="user-content-r0" href="#user-content-r0">fixtures/python-xunit-pytest.xml</a>
|
|
||||||
**10** tests were completed in **19ms** with **6** passed, **2** failed and **2** skipped.
|
|
||||||
|Test suite|Passed|Failed|Skipped|Time|
|
|
||||||
|:---|---:|---:|---:|---:|
|
|
||||||
|[pytest](#user-content-r0s0)|6 ✅|2 ❌|2 ⚪|19ms|
|
|
||||||
### ❌ <a id="user-content-r0s0" href="#user-content-r0s0">pytest</a>
|
|
||||||
```
|
|
||||||
tests.test_lib
|
|
||||||
✅ test_always_pass
|
|
||||||
✅ test_with_subtests
|
|
||||||
✅ test_parameterized[param1]
|
|
||||||
✅ test_parameterized[param2]
|
|
||||||
⚪ test_always_skip
|
|
||||||
❌ test_always_fail
|
|
||||||
assert False
|
|
||||||
⚪ test_expected_failure
|
|
||||||
❌ test_error
|
|
||||||
Exception: error
|
|
||||||
✅ test_with_record_property
|
|
||||||
custom_classname
|
|
||||||
✅ test_with_record_xml_attribute
|
|
||||||
```
|
|
||||||
|
|
@ -1,23 +0,0 @@
|
||||||

|
|
||||||
|Report|Passed|Failed|Skipped|Time|
|
|
||||||
|:---|---:|---:|---:|---:|
|
|
||||||
|[fixtures/python-xunit-unittest.xml](#user-content-r0)|4 ✅|2 ❌|2 ⚪|1ms|
|
|
||||||
## ❌ <a id="user-content-r0" href="#user-content-r0">fixtures/python-xunit-unittest.xml</a>
|
|
||||||
**8** tests were completed in **1ms** with **4** passed, **2** failed and **2** skipped.
|
|
||||||
|Test suite|Passed|Failed|Skipped|Time|
|
|
||||||
|:---|---:|---:|---:|---:|
|
|
||||||
|[TestAcme-20251114214921](#user-content-r0s0)|4 ✅|2 ❌|2 ⚪|1ms|
|
|
||||||
### ❌ <a id="user-content-r0s0" href="#user-content-r0s0">TestAcme-20251114214921</a>
|
|
||||||
```
|
|
||||||
TestAcme
|
|
||||||
✅ test_always_pass
|
|
||||||
✅ test_parameterized_0_param1
|
|
||||||
✅ test_parameterized_1_param2
|
|
||||||
✅ test_with_subtests
|
|
||||||
❌ test_always_fail
|
|
||||||
AssertionError: failed
|
|
||||||
❌ test_error
|
|
||||||
Exception: error
|
|
||||||
⚪ test_always_skip
|
|
||||||
⚪ test_expected_failure
|
|
||||||
```
|
|
||||||
|
|
@ -1,192 +0,0 @@
|
||||||
// Jest Snapshot v1, https://jestjs.io/docs/snapshot-testing
|
|
||||||
|
|
||||||
exports[`python-xunit pytest report report from python test results matches snapshot 1`] = `
|
|
||||||
TestRunResult {
|
|
||||||
"path": "fixtures/python-xunit-pytest.xml",
|
|
||||||
"suites": [
|
|
||||||
TestSuiteResult {
|
|
||||||
"groups": [
|
|
||||||
TestGroupResult {
|
|
||||||
"name": "tests.test_lib",
|
|
||||||
"tests": [
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_always_pass",
|
|
||||||
"result": "success",
|
|
||||||
"time": 2,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_with_subtests",
|
|
||||||
"result": "success",
|
|
||||||
"time": 5,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_parameterized[param1]",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_parameterized[param2]",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_always_skip",
|
|
||||||
"result": "skipped",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": {
|
|
||||||
"details": "def test_always_fail():
|
|
||||||
> assert False
|
|
||||||
E assert False
|
|
||||||
|
|
||||||
tests/test_lib.py:25: AssertionError
|
|
||||||
",
|
|
||||||
"line": undefined,
|
|
||||||
"message": "assert False",
|
|
||||||
"path": undefined,
|
|
||||||
},
|
|
||||||
"name": "test_always_fail",
|
|
||||||
"result": "failed",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_expected_failure",
|
|
||||||
"result": "skipped",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": {
|
|
||||||
"details": "def test_error():
|
|
||||||
> raise Exception("error")
|
|
||||||
E Exception: error
|
|
||||||
|
|
||||||
tests/test_lib.py:32: Exception
|
|
||||||
",
|
|
||||||
"line": undefined,
|
|
||||||
"message": "Exception: error",
|
|
||||||
"path": undefined,
|
|
||||||
},
|
|
||||||
"name": "test_error",
|
|
||||||
"result": "failed",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_with_record_property",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
TestGroupResult {
|
|
||||||
"name": "custom_classname",
|
|
||||||
"tests": [
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_with_record_xml_attribute",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"name": "pytest",
|
|
||||||
"totalTime": 19,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"totalTime": undefined,
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
||||||
exports[`python-xunit unittest report report from python test results matches snapshot 1`] = `
|
|
||||||
TestRunResult {
|
|
||||||
"path": "fixtures/python-xunit-unittest.xml",
|
|
||||||
"suites": [
|
|
||||||
TestSuiteResult {
|
|
||||||
"groups": [
|
|
||||||
TestGroupResult {
|
|
||||||
"name": "TestAcme",
|
|
||||||
"tests": [
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_always_pass",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_parameterized_0_param1",
|
|
||||||
"result": "success",
|
|
||||||
"time": 1,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_parameterized_1_param2",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_with_subtests",
|
|
||||||
"result": "success",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": {
|
|
||||||
"details": "Traceback (most recent call last):
|
|
||||||
File "/Users/foo/Projects/python-test/tests/test_lib.py", line 24, in test_always_fail
|
|
||||||
self.fail("failed")
|
|
||||||
AssertionError: failed
|
|
||||||
",
|
|
||||||
"line": undefined,
|
|
||||||
"message": "AssertionError: failed",
|
|
||||||
"path": undefined,
|
|
||||||
},
|
|
||||||
"name": "test_always_fail",
|
|
||||||
"result": "failed",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": {
|
|
||||||
"details": "Traceback (most recent call last):
|
|
||||||
File "/Users/foo/Projects/python-test/tests/test_lib.py", line 31, in test_error
|
|
||||||
raise Exception("error")
|
|
||||||
Exception: error
|
|
||||||
",
|
|
||||||
"line": undefined,
|
|
||||||
"message": "Exception: error",
|
|
||||||
"path": undefined,
|
|
||||||
},
|
|
||||||
"name": "test_error",
|
|
||||||
"result": "failed",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_always_skip",
|
|
||||||
"result": "skipped",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
TestCaseResult {
|
|
||||||
"error": undefined,
|
|
||||||
"name": "test_expected_failure",
|
|
||||||
"result": "skipped",
|
|
||||||
"time": 0,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"name": "TestAcme-20251114214921",
|
|
||||||
"totalTime": 1,
|
|
||||||
},
|
|
||||||
],
|
|
||||||
"totalTime": 1,
|
|
||||||
}
|
|
||||||
`;
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<testsuites name="pytest tests">
|
|
||||||
<testsuite name="pytest" errors="0" failures="2" skipped="2" tests="15" time="0.019"
|
|
||||||
timestamp="2025-11-15T11:51:49.548396-05:00" hostname="Mac.hsd1.va.comcast.net">
|
|
||||||
<properties>
|
|
||||||
<property name="custom_prop" value="custom_val"/>
|
|
||||||
</properties>
|
|
||||||
<testcase classname="tests.test_lib" name="test_always_pass" time="0.002"/>
|
|
||||||
<testcase classname="tests.test_lib" name="test_with_subtests" time="0.005"/>
|
|
||||||
<testcase classname="tests.test_lib" name="test_parameterized[param1]" time="0.000"/>
|
|
||||||
<testcase classname="tests.test_lib" name="test_parameterized[param2]" time="0.000"/>
|
|
||||||
<testcase classname="tests.test_lib" name="test_always_skip" time="0.000">
|
|
||||||
<skipped type="pytest.skip" message="skipped">/Users/mike/Projects/python-test/tests/test_lib.py:20: skipped
|
|
||||||
</skipped>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="tests.test_lib" name="test_always_fail" time="0.000">
|
|
||||||
<failure message="assert False">def test_always_fail():
|
|
||||||
> assert False
|
|
||||||
E assert False
|
|
||||||
|
|
||||||
tests/test_lib.py:25: AssertionError
|
|
||||||
</failure>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="tests.test_lib" name="test_expected_failure" time="0.000">
|
|
||||||
<skipped type="pytest.xfail" message=""/>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="tests.test_lib" name="test_error" time="0.000">
|
|
||||||
<failure message="Exception: error">def test_error():
|
|
||||||
> raise Exception("error")
|
|
||||||
E Exception: error
|
|
||||||
|
|
||||||
tests/test_lib.py:32: Exception
|
|
||||||
</failure>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="tests.test_lib" name="test_with_record_property" time="0.000">
|
|
||||||
<properties>
|
|
||||||
<property name="example_key" value="1"/>
|
|
||||||
</properties>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="custom_classname" name="test_with_record_xml_attribute" time="0.000"/>
|
|
||||||
</testsuite>
|
|
||||||
</testsuites>
|
|
||||||
|
|
@ -1,27 +0,0 @@
|
||||||
<?xml version="1.0" encoding="UTF-8"?>
|
|
||||||
<testsuite name="TestAcme-20251114214921" tests="8" file=".py" time="0.001" timestamp="2025-11-14T21:49:22" failures="1" errors="1" skipped="2">
|
|
||||||
<testcase classname="TestAcme" name="test_always_pass" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="8"/>
|
|
||||||
<testcase classname="TestAcme" name="test_parameterized_0_param1" time="0.001" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="618"/>
|
|
||||||
<testcase classname="TestAcme" name="test_parameterized_1_param2" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="618"/>
|
|
||||||
<testcase classname="TestAcme" name="test_with_subtests" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="11"/>
|
|
||||||
<testcase classname="TestAcme" name="test_always_fail" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="23">
|
|
||||||
<failure type="AssertionError" message="failed"><![CDATA[Traceback (most recent call last):
|
|
||||||
File "/Users/foo/Projects/python-test/tests/test_lib.py", line 24, in test_always_fail
|
|
||||||
self.fail("failed")
|
|
||||||
AssertionError: failed
|
|
||||||
]]></failure>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="TestAcme" name="test_error" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="30">
|
|
||||||
<error type="Exception" message="error"><![CDATA[Traceback (most recent call last):
|
|
||||||
File "/Users/foo/Projects/python-test/tests/test_lib.py", line 31, in test_error
|
|
||||||
raise Exception("error")
|
|
||||||
Exception: error
|
|
||||||
]]></error>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="TestAcme" name="test_always_skip" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="20">
|
|
||||||
<skipped type="skip" message="skipped"/>
|
|
||||||
</testcase>
|
|
||||||
<testcase classname="TestAcme" name="test_expected_failure" time="0.000" timestamp="2025-11-14T21:49:22" file="tests/test_lib.py" line="26">
|
|
||||||
<skipped type="XFAIL" message="expected failure: (<class 'AssertionError'>, AssertionError('expected failure'), <traceback object at 0x100c125c0>)"/>
|
|
||||||
</testcase>
|
|
||||||
</testsuite>
|
|
||||||
|
|
@ -1,93 +0,0 @@
|
||||||
import * as fs from 'fs'
|
|
||||||
import * as path from 'path'
|
|
||||||
|
|
||||||
import {PythonXunitParser} from '../src/parsers/python-xunit/python-xunit-parser'
|
|
||||||
import {ParseOptions} from '../src/test-parser'
|
|
||||||
import {DEFAULT_OPTIONS, getReport} from '../src/report/get-report'
|
|
||||||
import {normalizeFilePath} from '../src/utils/path-utils'
|
|
||||||
|
|
||||||
const defaultOpts: ParseOptions = {
|
|
||||||
parseErrors: true,
|
|
||||||
trackedFiles: []
|
|
||||||
}
|
|
||||||
|
|
||||||
describe('python-xunit unittest report', () => {
|
|
||||||
const fixturePath = path.join(__dirname, 'fixtures', 'python-xunit-unittest.xml')
|
|
||||||
const filePath = normalizeFilePath(path.relative(__dirname, fixturePath))
|
|
||||||
const fileContent = fs.readFileSync(fixturePath, {encoding: 'utf8'})
|
|
||||||
const outputPath = path.join(__dirname, '__outputs__', 'python-xunit-unittest.md')
|
|
||||||
|
|
||||||
it('report from python test results matches snapshot', async () => {
|
|
||||||
const trackedFiles = ['tests/test_lib.py']
|
|
||||||
const opts: ParseOptions = {
|
|
||||||
...defaultOpts,
|
|
||||||
trackedFiles
|
|
||||||
}
|
|
||||||
|
|
||||||
const parser = new PythonXunitParser(opts)
|
|
||||||
const result = await parser.parse(filePath, fileContent)
|
|
||||||
expect(result).toMatchSnapshot()
|
|
||||||
|
|
||||||
const report = getReport([result])
|
|
||||||
fs.mkdirSync(path.dirname(outputPath), {recursive: true})
|
|
||||||
fs.writeFileSync(outputPath, report)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('report does not include a title by default', async () => {
|
|
||||||
const parser = new PythonXunitParser(defaultOpts)
|
|
||||||
const result = await parser.parse(filePath, fileContent)
|
|
||||||
const report = getReport([result])
|
|
||||||
// Report should have the badge as the first line
|
|
||||||
expect(report).toMatch(/^!\[Tests failed]/)
|
|
||||||
})
|
|
||||||
|
|
||||||
it.each([
|
|
||||||
['empty string', ''],
|
|
||||||
['space', ' '],
|
|
||||||
['tab', '\t'],
|
|
||||||
['newline', '\n']
|
|
||||||
])('report does not include a title when configured value is %s', async (_, reportTitle) => {
|
|
||||||
const parser = new PythonXunitParser(defaultOpts)
|
|
||||||
const result = await parser.parse(filePath, fileContent)
|
|
||||||
const report = getReport([result], {
|
|
||||||
...DEFAULT_OPTIONS,
|
|
||||||
reportTitle
|
|
||||||
})
|
|
||||||
// Report should have the badge as the first line
|
|
||||||
expect(report).toMatch(/^!\[Tests failed]/)
|
|
||||||
})
|
|
||||||
|
|
||||||
it('report includes a custom report title', async () => {
|
|
||||||
const parser = new PythonXunitParser(defaultOpts)
|
|
||||||
const result = await parser.parse(filePath, fileContent)
|
|
||||||
const report = getReport([result], {
|
|
||||||
...DEFAULT_OPTIONS,
|
|
||||||
reportTitle: 'My Custom Title'
|
|
||||||
})
|
|
||||||
// Report should have the title as the first line
|
|
||||||
expect(report).toMatch(/^# My Custom Title\n/)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
||||||
describe('python-xunit pytest report', () => {
|
|
||||||
const fixturePath = path.join(__dirname, 'fixtures', 'python-xunit-pytest.xml')
|
|
||||||
const filePath = normalizeFilePath(path.relative(__dirname, fixturePath))
|
|
||||||
const fileContent = fs.readFileSync(fixturePath, {encoding: 'utf8'})
|
|
||||||
const outputPath = path.join(__dirname, '__outputs__', 'python-xunit-pytest.md')
|
|
||||||
|
|
||||||
it('report from python test results matches snapshot', async () => {
|
|
||||||
const trackedFiles = ['tests/test_lib.py']
|
|
||||||
const opts: ParseOptions = {
|
|
||||||
...defaultOpts,
|
|
||||||
trackedFiles
|
|
||||||
}
|
|
||||||
|
|
||||||
const parser = new PythonXunitParser(opts)
|
|
||||||
const result = await parser.parse(filePath, fileContent)
|
|
||||||
expect(result).toMatchSnapshot()
|
|
||||||
|
|
||||||
const report = getReport([result])
|
|
||||||
fs.mkdirSync(path.dirname(outputPath), {recursive: true})
|
|
||||||
fs.writeFileSync(outputPath, report)
|
|
||||||
})
|
|
||||||
})
|
|
||||||
|
|
@ -32,7 +32,6 @@ inputs:
|
||||||
- java-junit
|
- java-junit
|
||||||
- jest-junit
|
- jest-junit
|
||||||
- mocha-json
|
- mocha-json
|
||||||
- python-xunit
|
|
||||||
- rspec-json
|
- rspec-json
|
||||||
- swift-xunit
|
- swift-xunit
|
||||||
required: true
|
required: true
|
||||||
|
|
|
||||||
893
dist/index.js
generated
vendored
893
dist/index.js
generated
vendored
File diff suppressed because it is too large
Load diff
80
dist/licenses.txt
generated
vendored
80
dist/licenses.txt
generated
vendored
|
|
@ -1350,62 +1350,48 @@ CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
|
|
||||||
|
|
||||||
sax
|
sax
|
||||||
BlueOak-1.0.0
|
ISC
|
||||||
# Blue Oak Model License
|
The ISC License
|
||||||
|
|
||||||
Version 1.0.0
|
Copyright (c) Isaac Z. Schlueter and Contributors
|
||||||
|
|
||||||
## Purpose
|
Permission to use, copy, modify, and/or distribute this software for any
|
||||||
|
purpose with or without fee is hereby granted, provided that the above
|
||||||
|
copyright notice and this permission notice appear in all copies.
|
||||||
|
|
||||||
This license gives everyone as much permission to work with
|
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
|
||||||
this software as possible, while protecting contributors
|
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
|
||||||
from liability.
|
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
|
||||||
|
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
||||||
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
||||||
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR
|
||||||
|
IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
## Acceptance
|
====
|
||||||
|
|
||||||
In order to receive this license, you must agree to its
|
`String.fromCodePoint` by Mathias Bynens used according to terms of MIT
|
||||||
rules. The rules of this license are both obligations
|
License, as follows:
|
||||||
under that agreement and conditions to your license.
|
|
||||||
You must not do anything with this software that triggers
|
|
||||||
a rule that you cannot or will not follow.
|
|
||||||
|
|
||||||
## Copyright
|
Copyright Mathias Bynens <https://mathiasbynens.be/>
|
||||||
|
|
||||||
Each contributor licenses you to do everything with this
|
Permission is hereby granted, free of charge, to any person obtaining
|
||||||
software that would otherwise infringe that contributor's
|
a copy of this software and associated documentation files (the
|
||||||
copyright in it.
|
"Software"), to deal in the Software without restriction, including
|
||||||
|
without limitation the rights to use, copy, modify, merge, publish,
|
||||||
|
distribute, sublicense, and/or sell copies of the Software, and to
|
||||||
|
permit persons to whom the Software is furnished to do so, subject to
|
||||||
|
the following conditions:
|
||||||
|
|
||||||
## Notices
|
The above copyright notice and this permission notice shall be
|
||||||
|
included in all copies or substantial portions of the Software.
|
||||||
|
|
||||||
You must ensure that everyone who gets a copy of
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
||||||
any part of this software from you, with or without
|
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
||||||
changes, also gets the text of this license or a link to
|
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
||||||
<https://blueoakcouncil.org/license/1.0.0>.
|
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
||||||
|
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
||||||
## Excuse
|
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
||||||
|
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
If anyone notifies you in writing that you have not
|
|
||||||
complied with [Notices](#notices), you can keep your
|
|
||||||
license by taking all practical steps to comply within 30
|
|
||||||
days after the notice. If you do not do so, your license
|
|
||||||
ends immediately.
|
|
||||||
|
|
||||||
## Patent
|
|
||||||
|
|
||||||
Each contributor licenses you to do everything with this
|
|
||||||
software that would otherwise infringe any patent claims
|
|
||||||
they can license or become able to license.
|
|
||||||
|
|
||||||
## Reliability
|
|
||||||
|
|
||||||
No contributor can revoke this license.
|
|
||||||
|
|
||||||
## No Liability
|
|
||||||
|
|
||||||
***As far as the law allows, this software comes as is,
|
|
||||||
without any warranty or condition, and no contributor
|
|
||||||
will be liable to anyone for any damages related to this
|
|
||||||
software or this license, under any kind of legal claim.***
|
|
||||||
|
|
||||||
|
|
||||||
to-regex-range
|
to-regex-range
|
||||||
|
|
|
||||||
7
package-lock.json
generated
7
package-lock.json
generated
|
|
@ -7580,10 +7580,9 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"node_modules/sax": {
|
"node_modules/sax": {
|
||||||
"version": "1.4.3",
|
"version": "1.2.4",
|
||||||
"resolved": "https://registry.npmjs.org/sax/-/sax-1.4.3.tgz",
|
"resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz",
|
||||||
"integrity": "sha512-yqYn1JhPczigF94DMS+shiDMjDowYO6y9+wB/4WgO0Y19jWYk0lQ4tuG5KI7kj4FTp1wxPj5IFfcrz/s1c3jjQ==",
|
"integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw=="
|
||||||
"license": "BlueOak-1.0.0"
|
|
||||||
},
|
},
|
||||||
"node_modules/semver": {
|
"node_modules/semver": {
|
||||||
"version": "7.7.3",
|
"version": "7.7.3",
|
||||||
|
|
|
||||||
|
|
@ -69,9 +69,6 @@
|
||||||
"ts-jest": "^29.4.5",
|
"ts-jest": "^29.4.5",
|
||||||
"typescript": "^5.9.3"
|
"typescript": "^5.9.3"
|
||||||
},
|
},
|
||||||
"overrides": {
|
|
||||||
"sax": "^1.4.3"
|
|
||||||
},
|
|
||||||
"jest-junit": {
|
"jest-junit": {
|
||||||
"suiteName": "jest tests",
|
"suiteName": "jest tests",
|
||||||
"outputDirectory": "__tests__/__results__",
|
"outputDirectory": "__tests__/__results__",
|
||||||
|
|
|
||||||
|
|
@ -17,9 +17,9 @@ import {GolangJsonParser} from './parsers/golang-json/golang-json-parser'
|
||||||
import {JavaJunitParser} from './parsers/java-junit/java-junit-parser'
|
import {JavaJunitParser} from './parsers/java-junit/java-junit-parser'
|
||||||
import {JestJunitParser} from './parsers/jest-junit/jest-junit-parser'
|
import {JestJunitParser} from './parsers/jest-junit/jest-junit-parser'
|
||||||
import {MochaJsonParser} from './parsers/mocha-json/mocha-json-parser'
|
import {MochaJsonParser} from './parsers/mocha-json/mocha-json-parser'
|
||||||
import {PythonXunitParser} from './parsers/python-xunit/python-xunit-parser'
|
|
||||||
import {RspecJsonParser} from './parsers/rspec-json/rspec-json-parser'
|
import {RspecJsonParser} from './parsers/rspec-json/rspec-json-parser'
|
||||||
import {SwiftXunitParser} from './parsers/swift-xunit/swift-xunit-parser'
|
import {SwiftXunitParser} from './parsers/swift-xunit/swift-xunit-parser'
|
||||||
|
|
||||||
import {normalizeDirPath, normalizeFilePath} from './utils/path-utils'
|
import {normalizeDirPath, normalizeFilePath} from './utils/path-utils'
|
||||||
import {getCheckRunContext} from './utils/github-utils'
|
import {getCheckRunContext} from './utils/github-utils'
|
||||||
|
|
||||||
|
|
@ -271,8 +271,6 @@ class TestReporter {
|
||||||
return new JestJunitParser(options)
|
return new JestJunitParser(options)
|
||||||
case 'mocha-json':
|
case 'mocha-json':
|
||||||
return new MochaJsonParser(options)
|
return new MochaJsonParser(options)
|
||||||
case 'python-xunit':
|
|
||||||
return new PythonXunitParser(options)
|
|
||||||
case 'rspec-json':
|
case 'rspec-json':
|
||||||
return new RspecJsonParser(options)
|
return new RspecJsonParser(options)
|
||||||
case 'swift-xunit':
|
case 'swift-xunit':
|
||||||
|
|
|
||||||
|
|
@ -1,8 +0,0 @@
|
||||||
import {ParseOptions} from '../../test-parser'
|
|
||||||
import {JavaJunitParser} from '../java-junit/java-junit-parser'
|
|
||||||
|
|
||||||
export class PythonXunitParser extends JavaJunitParser {
|
|
||||||
constructor(readonly options: ParseOptions) {
|
|
||||||
super(options)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue