mirror of
https://github.com/dorny/test-reporter.git
synced 2025-12-15 13:57:09 +01:00
Correct behavior for test cases with slashes
This commit is contained in:
parent
34f1c566ff
commit
a0398fb7dd
7 changed files with 228 additions and 78 deletions
|
|
@ -1,12 +1,12 @@
|
||||||

|

|
||||||
|Report|Passed|Failed|Skipped|Time|
|
|Report|Passed|Failed|Skipped|Time|
|
||||||
|:---|---:|---:|---:|---:|
|
|:---|---:|---:|---:|---:|
|
||||||
|fixtures/golang-json.json|3 ✅|5 ❌|1 ⚪|4s|
|
|fixtures/golang-json.json|5 ✅|6 ❌|1 ⚪|6s|
|
||||||
## ❌ <a id="user-content-r0" href="#user-content-r0">fixtures/golang-json.json</a>
|
## ❌ <a id="user-content-r0" href="#user-content-r0">fixtures/golang-json.json</a>
|
||||||
**9** tests were completed in **4s** with **3** passed, **5** failed and **1** skipped.
|
**12** tests were completed in **6s** with **5** passed, **6** failed and **1** skipped.
|
||||||
|Test suite|Passed|Failed|Skipped|Time|
|
|Test suite|Passed|Failed|Skipped|Time|
|
||||||
|:---|---:|---:|---:|---:|
|
|:---|---:|---:|---:|---:|
|
||||||
|[_/home/james_t/git/test-reporter/reports/go](#user-content-r0s0)|3 ✅|5 ❌|1 ⚪|4s|
|
|[_/home/james_t/git/test-reporter/reports/go](#user-content-r0s0)|5 ✅|6 ❌|1 ⚪|6s|
|
||||||
### ❌ <a id="user-content-r0s0" href="#user-content-r0s0">_/home/james_t/git/test-reporter/reports/go</a>
|
### ❌ <a id="user-content-r0s0" href="#user-content-r0s0">_/home/james_t/git/test-reporter/reports/go</a>
|
||||||
```
|
```
|
||||||
✅ TestPassing
|
✅ TestPassing
|
||||||
|
|
@ -14,10 +14,10 @@
|
||||||
calculator_test.go:19: expected 1+1 = 3, got 2
|
calculator_test.go:19: expected 1+1 = 3, got 2
|
||||||
|
|
||||||
❌ TestPanicInsideFunction
|
❌ TestPanicInsideFunction
|
||||||
calculator_test.go:71: caught panic: runtime error: integer divide by zero
|
calculator_test.go:76: caught panic: runtime error: integer divide by zero
|
||||||
|
|
||||||
❌ TestPanicInsideTest
|
❌ TestPanicInsideTest
|
||||||
calculator_test.go:71: caught panic: bad stuff
|
calculator_test.go:76: caught panic: bad stuff
|
||||||
|
|
||||||
⚪ TestSkipped
|
⚪ TestSkipped
|
||||||
calculator_test.go:45: skipping test
|
calculator_test.go:45: skipping test
|
||||||
|
|
@ -28,6 +28,11 @@ TestCases
|
||||||
✅ 1_+_2_=_3
|
✅ 1_+_2_=_3
|
||||||
✅ 4_+_7_=_11
|
✅ 4_+_7_=_11
|
||||||
❌ 2_+_3_=_4
|
❌ 2_+_3_=_4
|
||||||
calculator_test.go:62: expected 2 + 3 = 4, got 5
|
calculator_test.go:67: expected 2 + 3 = 4, got 5
|
||||||
|
|
||||||
|
❌ 1_/_2_=_1
|
||||||
|
calculator_test.go:67: expected 1 / 2 = 1, got 0
|
||||||
|
|
||||||
|
✅ 9_/_3_=_3
|
||||||
|
✅ 14_/_7_=_2
|
||||||
```
|
```
|
||||||
|
|
@ -13,7 +13,7 @@ TestRunResult {
|
||||||
"error": undefined,
|
"error": undefined,
|
||||||
"name": "TestPassing",
|
"name": "TestPassing",
|
||||||
"result": "success",
|
"result": "success",
|
||||||
"time": 90,
|
"time": 60,
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": {
|
"error": {
|
||||||
|
|
@ -24,13 +24,13 @@ TestRunResult {
|
||||||
},
|
},
|
||||||
"name": "TestFailing",
|
"name": "TestFailing",
|
||||||
"result": "failed",
|
"result": "failed",
|
||||||
"time": 760,
|
"time": 890,
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": {
|
"error": {
|
||||||
"details": "calculator_test.go:71: caught panic: runtime error: integer divide by zero
|
"details": "calculator_test.go:76: caught panic: runtime error: integer divide by zero
|
||||||
",
|
",
|
||||||
"message": "calculator_test.go:71: caught panic: runtime error: integer divide by zero
|
"message": "calculator_test.go:76: caught panic: runtime error: integer divide by zero
|
||||||
",
|
",
|
||||||
},
|
},
|
||||||
"name": "TestPanicInsideFunction",
|
"name": "TestPanicInsideFunction",
|
||||||
|
|
@ -39,9 +39,9 @@ TestRunResult {
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": {
|
"error": {
|
||||||
"details": "calculator_test.go:71: caught panic: bad stuff
|
"details": "calculator_test.go:76: caught panic: bad stuff
|
||||||
",
|
",
|
||||||
"message": "calculator_test.go:71: caught panic: bad stuff
|
"message": "calculator_test.go:76: caught panic: bad stuff
|
||||||
",
|
",
|
||||||
},
|
},
|
||||||
"name": "TestPanicInsideTest",
|
"name": "TestPanicInsideTest",
|
||||||
|
|
@ -57,7 +57,7 @@ TestRunResult {
|
||||||
},
|
},
|
||||||
"name": "TestSkipped",
|
"name": "TestSkipped",
|
||||||
"result": "skipped",
|
"result": "skipped",
|
||||||
"time": 110,
|
"time": 940,
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": {
|
"error": {
|
||||||
|
|
@ -66,7 +66,7 @@ TestRunResult {
|
||||||
},
|
},
|
||||||
"name": "TestCases",
|
"name": "TestCases",
|
||||||
"result": "failed",
|
"result": "failed",
|
||||||
"time": 1620,
|
"time": 2250,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
@ -77,24 +77,47 @@ TestRunResult {
|
||||||
"error": undefined,
|
"error": undefined,
|
||||||
"name": "1_+_2_=_3",
|
"name": "1_+_2_=_3",
|
||||||
"result": "success",
|
"result": "success",
|
||||||
"time": 540,
|
"time": 400,
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": undefined,
|
"error": undefined,
|
||||||
"name": "4_+_7_=_11",
|
"name": "4_+_7_=_11",
|
||||||
"result": "success",
|
"result": "success",
|
||||||
"time": 540,
|
"time": 460,
|
||||||
},
|
},
|
||||||
TestCaseResult {
|
TestCaseResult {
|
||||||
"error": {
|
"error": {
|
||||||
"details": "calculator_test.go:62: expected 2 + 3 = 4, got 5
|
"details": "calculator_test.go:67: expected 2 + 3 = 4, got 5
|
||||||
",
|
",
|
||||||
"message": "calculator_test.go:62: expected 2 + 3 = 4, got 5
|
"message": "calculator_test.go:67: expected 2 + 3 = 4, got 5
|
||||||
",
|
",
|
||||||
},
|
},
|
||||||
"name": "2_+_3_=_4",
|
"name": "2_+_3_=_4",
|
||||||
"result": "failed",
|
"result": "failed",
|
||||||
"time": 530,
|
"time": 90,
|
||||||
|
},
|
||||||
|
TestCaseResult {
|
||||||
|
"error": {
|
||||||
|
"details": "calculator_test.go:67: expected 1 / 2 = 1, got 0
|
||||||
|
",
|
||||||
|
"message": "calculator_test.go:67: expected 1 / 2 = 1, got 0
|
||||||
|
",
|
||||||
|
},
|
||||||
|
"name": "1_/_2_=_1",
|
||||||
|
"result": "failed",
|
||||||
|
"time": 920,
|
||||||
|
},
|
||||||
|
TestCaseResult {
|
||||||
|
"error": undefined,
|
||||||
|
"name": "9_/_3_=_3",
|
||||||
|
"result": "success",
|
||||||
|
"time": 340,
|
||||||
|
},
|
||||||
|
TestCaseResult {
|
||||||
|
"error": undefined,
|
||||||
|
"name": "14_/_7_=_2",
|
||||||
|
"result": "success",
|
||||||
|
"time": 40,
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
},
|
},
|
||||||
|
|
|
||||||
|
|
@ -1,46 +1,59 @@
|
||||||
{"Time":"2025-04-21T14:45:43.899731191-05:00","Action":"start","Package":"_/home/james_t/git/test-reporter/reports/go"}
|
{"Time":"2025-04-22T08:59:55.364618802-05:00","Action":"start","Package":"_/home/james_t/git/test-reporter/reports/go"}
|
||||||
{"Time":"2025-04-21T14:45:43.907303273-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing"}
|
{"Time":"2025-04-22T08:59:55.371779289-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing"}
|
||||||
{"Time":"2025-04-21T14:45:43.907333465-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":"=== RUN TestPassing\n"}
|
{"Time":"2025-04-22T08:59:55.371805677-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":"=== RUN TestPassing\n"}
|
||||||
{"Time":"2025-04-21T14:45:43.998551886-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":" calculator_test.go:11: pass!\n"}
|
{"Time":"2025-04-22T08:59:55.428201983-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":" calculator_test.go:11: pass!\n"}
|
||||||
{"Time":"2025-04-21T14:45:43.998572844-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":"--- PASS: TestPassing (0.09s)\n"}
|
{"Time":"2025-04-22T08:59:55.428265529-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Output":"--- PASS: TestPassing (0.06s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:43.998576971-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Elapsed":0.09}
|
{"Time":"2025-04-22T08:59:55.428285649-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPassing","Elapsed":0.06}
|
||||||
{"Time":"2025-04-21T14:45:43.998580617-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing"}
|
{"Time":"2025-04-22T08:59:55.428299886-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing"}
|
||||||
{"Time":"2025-04-21T14:45:43.998582298-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":"=== RUN TestFailing\n"}
|
{"Time":"2025-04-22T08:59:55.428309029-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":"=== RUN TestFailing\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763532195-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":" calculator_test.go:19: expected 1+1 = 3, got 2\n"}
|
{"Time":"2025-04-22T08:59:56.317425091-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":" calculator_test.go:19: expected 1+1 = 3, got 2\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763556975-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":"--- FAIL: TestFailing (0.76s)\n"}
|
{"Time":"2025-04-22T08:59:56.31748077-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Output":"--- FAIL: TestFailing (0.89s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763560434-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Elapsed":0.76}
|
{"Time":"2025-04-22T08:59:56.317493452-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestFailing","Elapsed":0.89}
|
||||||
{"Time":"2025-04-21T14:45:44.763564534-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction"}
|
{"Time":"2025-04-22T08:59:56.317506107-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction"}
|
||||||
{"Time":"2025-04-21T14:45:44.763566339-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":"=== RUN TestPanicInsideFunction\n"}
|
{"Time":"2025-04-22T08:59:56.317514487-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":"=== RUN TestPanicInsideFunction\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763568422-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":" calculator_test.go:71: caught panic: runtime error: integer divide by zero\n"}
|
{"Time":"2025-04-22T08:59:56.317530448-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":" calculator_test.go:76: caught panic: runtime error: integer divide by zero\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763571047-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":"--- FAIL: TestPanicInsideFunction (0.00s)\n"}
|
{"Time":"2025-04-22T08:59:56.317541866-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Output":"--- FAIL: TestPanicInsideFunction (0.00s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763575434-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Elapsed":0}
|
{"Time":"2025-04-22T08:59:56.317552981-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideFunction","Elapsed":0}
|
||||||
{"Time":"2025-04-21T14:45:44.763577511-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest"}
|
{"Time":"2025-04-22T08:59:56.317561057-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest"}
|
||||||
{"Time":"2025-04-21T14:45:44.763579734-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":"=== RUN TestPanicInsideTest\n"}
|
{"Time":"2025-04-22T08:59:56.317568742-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":"=== RUN TestPanicInsideTest\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763584346-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":" calculator_test.go:71: caught panic: bad stuff\n"}
|
{"Time":"2025-04-22T08:59:56.317584113-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":" calculator_test.go:76: caught panic: bad stuff\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763592493-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":"--- FAIL: TestPanicInsideTest (0.00s)\n"}
|
{"Time":"2025-04-22T08:59:56.317598524-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Output":"--- FAIL: TestPanicInsideTest (0.00s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.763595682-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Elapsed":0}
|
{"Time":"2025-04-22T08:59:56.317608268-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestPanicInsideTest","Elapsed":0}
|
||||||
{"Time":"2025-04-21T14:45:44.763598032-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped"}
|
{"Time":"2025-04-22T08:59:56.317615472-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped"}
|
||||||
{"Time":"2025-04-21T14:45:44.763600787-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":"=== RUN TestSkipped\n"}
|
{"Time":"2025-04-22T08:59:56.317623959-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":"=== RUN TestSkipped\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.875085305-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":" calculator_test.go:45: skipping test\n"}
|
{"Time":"2025-04-22T08:59:57.256475698-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":" calculator_test.go:45: skipping test\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.875128112-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":"--- SKIP: TestSkipped (0.11s)\n"}
|
{"Time":"2025-04-22T08:59:57.256536372-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Output":"--- SKIP: TestSkipped (0.94s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.875136234-05:00","Action":"skip","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Elapsed":0.11}
|
{"Time":"2025-04-22T08:59:57.256549142-05:00","Action":"skip","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestSkipped","Elapsed":0.94}
|
||||||
{"Time":"2025-04-21T14:45:44.87514445-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases"}
|
{"Time":"2025-04-22T08:59:57.256562053-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases"}
|
||||||
{"Time":"2025-04-21T14:45:44.87514908-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Output":"=== RUN TestCases\n"}
|
{"Time":"2025-04-22T08:59:57.256569388-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Output":"=== RUN TestCases\n"}
|
||||||
{"Time":"2025-04-21T14:45:44.875158116-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3"}
|
{"Time":"2025-04-22T08:59:57.256580104-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3"}
|
||||||
{"Time":"2025-04-21T14:45:44.875163067-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Output":"=== RUN TestCases/1_+_2_=_3\n"}
|
{"Time":"2025-04-22T08:59:57.256587408-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Output":"=== RUN TestCases/1_+_2_=_3\n"}
|
||||||
{"Time":"2025-04-21T14:45:45.413895814-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11"}
|
{"Time":"2025-04-22T08:59:57.653005399-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11"}
|
||||||
{"Time":"2025-04-21T14:45:45.413916191-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Output":"=== RUN TestCases/4_+_7_=_11\n"}
|
{"Time":"2025-04-22T08:59:57.653036336-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Output":"=== RUN TestCases/4_+_7_=_11\n"}
|
||||||
{"Time":"2025-04-21T14:45:45.957801848-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4"}
|
{"Time":"2025-04-22T08:59:58.112825221-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4"}
|
||||||
{"Time":"2025-04-21T14:45:45.957836789-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":"=== RUN TestCases/2_+_3_=_4\n"}
|
{"Time":"2025-04-22T08:59:58.112858016-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":"=== RUN TestCases/2_+_3_=_4\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492673381-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":" calculator_test.go:62: expected 2 + 3 = 4, got 5\n"}
|
{"Time":"2025-04-22T08:59:58.201204209-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":" calculator_test.go:67: expected 2 + 3 = 4, got 5\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492759645-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Output":"--- FAIL: TestCases (1.62s)\n"}
|
{"Time":"2025-04-22T08:59:58.201245827-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_/_2_=_1"}
|
||||||
{"Time":"2025-04-21T14:45:46.492779916-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Output":" --- PASS: TestCases/1_+_2_=_3 (0.54s)\n"}
|
{"Time":"2025-04-22T08:59:58.201255566-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_/_2_=_1","Output":"=== RUN TestCases/1_/_2_=_1\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492787539-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Elapsed":0.54}
|
{"Time":"2025-04-22T08:59:59.119852965-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_/_2_=_1","Output":" calculator_test.go:67: expected 1 / 2 = 1, got 0\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492795891-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Output":" --- PASS: TestCases/4_+_7_=_11 (0.54s)\n"}
|
{"Time":"2025-04-22T08:59:59.119877603-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/9_/_3_=_3"}
|
||||||
{"Time":"2025-04-21T14:45:46.492801851-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Elapsed":0.54}
|
{"Time":"2025-04-22T08:59:59.119879955-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/9_/_3_=_3","Output":"=== RUN TestCases/9_/_3_=_3\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492806634-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":" --- FAIL: TestCases/2_+_3_=_4 (0.53s)\n"}
|
{"Time":"2025-04-22T08:59:59.460576385-05:00","Action":"run","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/14_/_7_=_2"}
|
||||||
{"Time":"2025-04-21T14:45:46.492811453-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Elapsed":0.53}
|
{"Time":"2025-04-22T08:59:59.460607599-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/14_/_7_=_2","Output":"=== RUN TestCases/14_/_7_=_2\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.49281562-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Elapsed":1.62}
|
{"Time":"2025-04-22T08:59:59.504952672-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Output":"--- FAIL: TestCases (2.25s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.492821605-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Output":"FAIL\n"}
|
{"Time":"2025-04-22T08:59:59.504995938-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Output":" --- PASS: TestCases/1_+_2_=_3 (0.40s)\n"}
|
||||||
{"Time":"2025-04-21T14:45:46.493310745-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Output":"FAIL\t_/home/james_t/git/test-reporter/reports/go\t2.593s\n"}
|
{"Time":"2025-04-22T08:59:59.505006062-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_+_2_=_3","Elapsed":0.4}
|
||||||
{"Time":"2025-04-21T14:45:46.493343801-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Elapsed":2.594}
|
{"Time":"2025-04-22T08:59:59.505017551-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Output":" --- PASS: TestCases/4_+_7_=_11 (0.46s)\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505026099-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/4_+_7_=_11","Elapsed":0.46}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505033963-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Output":" --- FAIL: TestCases/2_+_3_=_4 (0.09s)\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505042238-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/2_+_3_=_4","Elapsed":0.09}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505050917-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_/_2_=_1","Output":" --- FAIL: TestCases/1_/_2_=_1 (0.92s)\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505059901-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/1_/_2_=_1","Elapsed":0.92}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505068125-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/9_/_3_=_3","Output":" --- PASS: TestCases/9_/_3_=_3 (0.34s)\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505076976-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/9_/_3_=_3","Elapsed":0.34}
|
||||||
|
{"Time":"2025-04-22T08:59:59.5050845-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/14_/_7_=_2","Output":" --- PASS: TestCases/14_/_7_=_2 (0.04s)\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505091554-05:00","Action":"pass","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases/14_/_7_=_2","Elapsed":0.04}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505098998-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Test":"TestCases","Elapsed":2.25}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505107502-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Output":"FAIL\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505552861-05:00","Action":"output","Package":"_/home/james_t/git/test-reporter/reports/go","Output":"FAIL\t_/home/james_t/git/test-reporter/reports/go\t4.141s\n"}
|
||||||
|
{"Time":"2025-04-22T08:59:59.505584529-05:00","Action":"fail","Package":"_/home/james_t/git/test-reporter/reports/go","Elapsed":4.141}
|
||||||
|
|
|
||||||
|
|
@ -1,17 +1,17 @@
|
||||||
import * as fs from 'fs'
|
import * as fs from 'fs'
|
||||||
import * as path from 'path'
|
import * as path from 'path'
|
||||||
|
|
||||||
import { GolangJsonParser } from '../src/parsers/golang-json/golang-json-parser'
|
import {GolangJsonParser} from '../src/parsers/golang-json/golang-json-parser'
|
||||||
import { ParseOptions } from '../src/test-parser'
|
import {ParseOptions} from '../src/test-parser'
|
||||||
import { getReport } from '../src/report/get-report'
|
import {getReport} from '../src/report/get-report'
|
||||||
import { normalizeFilePath } from '../src/utils/path-utils'
|
import {normalizeFilePath} from '../src/utils/path-utils'
|
||||||
|
|
||||||
describe('golang-json tests', () => {
|
describe('golang-json tests', () => {
|
||||||
it('report from ./reports/dotnet test results matches snapshot', async () => {
|
it('report from ./reports/dotnet test results matches snapshot', async () => {
|
||||||
const fixturePath = path.join(__dirname, 'fixtures', 'golang-json.json')
|
const fixturePath = path.join(__dirname, 'fixtures', 'golang-json.json')
|
||||||
const outputPath = path.join(__dirname, '__outputs__', 'golang-json.md')
|
const outputPath = path.join(__dirname, '__outputs__', 'golang-json.md')
|
||||||
const filePath = normalizeFilePath(path.relative(__dirname, fixturePath))
|
const filePath = normalizeFilePath(path.relative(__dirname, fixturePath))
|
||||||
const fileContent = fs.readFileSync(fixturePath, { encoding: 'utf8' })
|
const fileContent = fs.readFileSync(fixturePath, {encoding: 'utf8'})
|
||||||
|
|
||||||
const opts: ParseOptions = {
|
const opts: ParseOptions = {
|
||||||
parseErrors: true,
|
parseErrors: true,
|
||||||
|
|
@ -23,7 +23,7 @@ describe('golang-json tests', () => {
|
||||||
expect(result).toMatchSnapshot()
|
expect(result).toMatchSnapshot()
|
||||||
|
|
||||||
const report = getReport([result])
|
const report = getReport([result])
|
||||||
fs.mkdirSync(path.dirname(outputPath), { recursive: true })
|
fs.mkdirSync(path.dirname(outputPath), {recursive: true})
|
||||||
fs.writeFileSync(outputPath, report)
|
fs.writeFileSync(outputPath, report)
|
||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
|
||||||
103
dist/index.js
generated
vendored
103
dist/index.js
generated
vendored
|
|
@ -273,6 +273,7 @@ const get_report_1 = __nccwpck_require__(7070);
|
||||||
const dart_json_parser_1 = __nccwpck_require__(1254);
|
const dart_json_parser_1 = __nccwpck_require__(1254);
|
||||||
const dotnet_nunit_parser_1 = __nccwpck_require__(6394);
|
const dotnet_nunit_parser_1 = __nccwpck_require__(6394);
|
||||||
const dotnet_trx_parser_1 = __nccwpck_require__(1658);
|
const dotnet_trx_parser_1 = __nccwpck_require__(1658);
|
||||||
|
const golang_json_parser_1 = __nccwpck_require__(5162);
|
||||||
const java_junit_parser_1 = __nccwpck_require__(8342);
|
const java_junit_parser_1 = __nccwpck_require__(8342);
|
||||||
const jest_junit_parser_1 = __nccwpck_require__(1042);
|
const jest_junit_parser_1 = __nccwpck_require__(1042);
|
||||||
const mocha_json_parser_1 = __nccwpck_require__(5402);
|
const mocha_json_parser_1 = __nccwpck_require__(5402);
|
||||||
|
|
@ -475,6 +476,8 @@ class TestReporter {
|
||||||
return new dotnet_nunit_parser_1.DotnetNunitParser(options);
|
return new dotnet_nunit_parser_1.DotnetNunitParser(options);
|
||||||
case 'dotnet-trx':
|
case 'dotnet-trx':
|
||||||
return new dotnet_trx_parser_1.DotnetTrxParser(options);
|
return new dotnet_trx_parser_1.DotnetTrxParser(options);
|
||||||
|
case 'golang-json':
|
||||||
|
return new golang_json_parser_1.GolangJsonParser(options);
|
||||||
case 'flutter-json':
|
case 'flutter-json':
|
||||||
return new dart_json_parser_1.DartJsonParser(options, 'flutter');
|
return new dart_json_parser_1.DartJsonParser(options, 'flutter');
|
||||||
case 'java-junit':
|
case 'java-junit':
|
||||||
|
|
@ -1066,6 +1069,106 @@ class DotnetTrxParser {
|
||||||
exports.DotnetTrxParser = DotnetTrxParser;
|
exports.DotnetTrxParser = DotnetTrxParser;
|
||||||
|
|
||||||
|
|
||||||
|
/***/ }),
|
||||||
|
|
||||||
|
/***/ 5162:
|
||||||
|
/***/ ((__unused_webpack_module, exports, __nccwpck_require__) => {
|
||||||
|
|
||||||
|
"use strict";
|
||||||
|
|
||||||
|
Object.defineProperty(exports, "__esModule", ({ value: true }));
|
||||||
|
exports.GolangJsonParser = void 0;
|
||||||
|
const test_results_1 = __nccwpck_require__(613);
|
||||||
|
class GolangJsonParser {
|
||||||
|
options;
|
||||||
|
assumedWorkDir;
|
||||||
|
constructor(options) {
|
||||||
|
this.options = options;
|
||||||
|
}
|
||||||
|
async parse(path, content) {
|
||||||
|
const events = await this.getGolangTestEvents(path, content);
|
||||||
|
return this.getTestRunResult(path, events);
|
||||||
|
}
|
||||||
|
async getGolangTestEvents(path, content) {
|
||||||
|
return content.trim().split('\n').map((line, index) => {
|
||||||
|
try {
|
||||||
|
return JSON.parse(line);
|
||||||
|
}
|
||||||
|
catch (e) {
|
||||||
|
throw new Error(`Invalid JSON at ${path} line ${index + 1}\n\n${e}`);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
getTestRunResult(path, events) {
|
||||||
|
const eventGroups = new Map();
|
||||||
|
for (const event of events) {
|
||||||
|
if (!event.Test) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
const k = `${event.Package}/${event.Test}`;
|
||||||
|
let g = eventGroups.get(k);
|
||||||
|
if (!g) {
|
||||||
|
g = [];
|
||||||
|
eventGroups.set(k, g);
|
||||||
|
}
|
||||||
|
g.push(event);
|
||||||
|
}
|
||||||
|
const suites = [];
|
||||||
|
for (const eventGroup of eventGroups.values()) {
|
||||||
|
const event = eventGroup[0];
|
||||||
|
let suite = suites.find(s => s.name === event.Package);
|
||||||
|
if (!suite) {
|
||||||
|
suite = new test_results_1.TestSuiteResult(event.Package, []);
|
||||||
|
suites.push(suite);
|
||||||
|
}
|
||||||
|
if (!event.Test) {
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
let groupName;
|
||||||
|
let rest;
|
||||||
|
[groupName, ...rest] = event.Test.split('/');
|
||||||
|
let testName = rest.join('/');
|
||||||
|
if (!testName) {
|
||||||
|
testName = groupName;
|
||||||
|
groupName = null;
|
||||||
|
}
|
||||||
|
let group = suite.groups.find(g => g.name === groupName);
|
||||||
|
if (!group) {
|
||||||
|
group = new test_results_1.TestGroupResult(groupName, []);
|
||||||
|
suite.groups.push(group);
|
||||||
|
}
|
||||||
|
const lastEvent = eventGroup.at(-1);
|
||||||
|
const result = lastEvent.Action === 'pass' ? 'success'
|
||||||
|
: lastEvent.Action === 'skip' ? 'skipped'
|
||||||
|
: 'failed';
|
||||||
|
if (lastEvent.Elapsed === undefined) {
|
||||||
|
throw new Error('missing elapsed on final test event');
|
||||||
|
}
|
||||||
|
const time = lastEvent.Elapsed * 1000;
|
||||||
|
let error = undefined;
|
||||||
|
if (result !== 'success') {
|
||||||
|
const outputEvents = eventGroup
|
||||||
|
.filter(e => e.Action === 'output')
|
||||||
|
.map(e => e.Output ?? '')
|
||||||
|
// Go output prepends indentation to help group tests - remove it
|
||||||
|
.map(o => o.replace(/^ /, ''));
|
||||||
|
// First and last lines will be generic "test started" and "test finished" lines - remove them
|
||||||
|
outputEvents.splice(0, 1);
|
||||||
|
outputEvents.splice(-1, 1);
|
||||||
|
const details = outputEvents.join('');
|
||||||
|
error = {
|
||||||
|
message: details,
|
||||||
|
details: details
|
||||||
|
};
|
||||||
|
}
|
||||||
|
group.tests.push(new test_results_1.TestCaseResult(testName, result, time, error));
|
||||||
|
}
|
||||||
|
return new test_results_1.TestRunResult(path, suites);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.GolangJsonParser = GolangJsonParser;
|
||||||
|
|
||||||
|
|
||||||
/***/ }),
|
/***/ }),
|
||||||
|
|
||||||
/***/ 8342:
|
/***/ 8342:
|
||||||
|
|
|
||||||
|
|
@ -48,16 +48,21 @@ func TestSkipped(t *testing.T) {
|
||||||
func TestCases(t *testing.T) {
|
func TestCases(t *testing.T) {
|
||||||
for _, tc := range []struct {
|
for _, tc := range []struct {
|
||||||
name string
|
name string
|
||||||
|
fn func(int, int) int
|
||||||
a, b, c int
|
a, b, c int
|
||||||
}{
|
}{
|
||||||
{"1 + 2 = 3", 1, 2, 3},
|
{"1 + 2 = 3", CalculatorSum, 1, 2, 3},
|
||||||
{"4 + 7 = 11", 4, 7, 11},
|
{"4 + 7 = 11", CalculatorSum, 4, 7, 11},
|
||||||
{"2 + 3 = 4", 2, 3, 4},
|
{"2 + 3 = 4", CalculatorSum, 2, 3, 4},
|
||||||
|
|
||||||
|
{"1 / 2 = 1", CalculatorDivide, 1, 2, 1},
|
||||||
|
{"9 / 3 = 3", CalculatorDivide, 9, 3, 3},
|
||||||
|
{"14 / 7 = 2", CalculatorDivide, 14, 7, 2},
|
||||||
} {
|
} {
|
||||||
t.Run(tc.name, func(t *testing.T) {
|
t.Run(tc.name, func(t *testing.T) {
|
||||||
randomSleep()
|
randomSleep()
|
||||||
|
|
||||||
c := CalculatorSum(tc.a, tc.b)
|
c := tc.fn(tc.a, tc.b)
|
||||||
if c != tc.c {
|
if c != tc.c {
|
||||||
t.Fatalf("expected %s, got %d", tc.name, c)
|
t.Fatalf("expected %s, got %d", tc.name, c)
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -64,8 +64,9 @@ export class GolangJsonParser implements TestParser {
|
||||||
}
|
}
|
||||||
|
|
||||||
let groupName: string | null
|
let groupName: string | null
|
||||||
let testName: string
|
let rest: string[]
|
||||||
[groupName, testName] = event.Test.split('/', 2)
|
[groupName, ...rest] = event.Test.split('/')
|
||||||
|
let testName = rest.join('/')
|
||||||
if (!testName) {
|
if (!testName) {
|
||||||
testName = groupName
|
testName = groupName
|
||||||
groupName = null
|
groupName = null
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue