-
Notifications
You must be signed in to change notification settings - Fork 60
/
Copy pathjest.customSummaryReporter.js
43 lines (40 loc) · 2.06 KB
/
jest.customSummaryReporter.js
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
/* eslint-disable no-console */
/**
* @dwertheimer's custom Jest reporter to keep Jest output noise to a minimum */
// Just summarize the results and failures at the end of the test run
// run like so:
// jest **/*.test.js --reporters jest-silent-reporter --reporters ./jest.customSummaryReporter.js
const colors = require('chalk')
class CustomReporter {
constructor(globalConfig, reporterOptions, reporterContext) {
this._globalConfig = globalConfig
this._options = reporterOptions
this._context = reporterContext
}
// eslint-disable-next-line no-unused-vars
onRunComplete(testContexts, results) {
// console.log('Custom reporter output:')
// console.log('global config: ', this._globalConfig)
// console.log('options for this reporter from Jest config: ', this._options)
// console.log('reporter context passed from test scheduler: ', this._context)
// console.log('\n\ntest testContexts: \n', testContexts)
// console.log('\n\ntest results: \n', results)
const failedObjects = results?.testResults?.filter((result) => result.numFailingTests > 0) || []
// console.log(failedObjects)
const activeTests = results.numTotalTests - results.numPendingTests
const fails = results.numFailedTests
? colors.red.inverse(` ${results.numFailedTests} tests failed in ${failedObjects.length} test suite${failedObjects.length > 1 ? 's ' : ' '}`)
: ``
const pct = results.numFailedTests ? '' : colors.green.inverse(` (100%) `)
const pass = `${results.numFailedTests ? ', ' : ''}${colors.green(`${results.numPassedTests}/${activeTests} passed ${pct}`)}`
const outOf = `out of ${results.numTotalTests} tests in ${results.numTotalTestSuites} suites (${results.numPendingTests} tests skipped)`
const msg = `Test Results: ${fails}${results.numFailedTests ? ' ' : ''}${pass} ${outOf}`
console.log(msg)
if (results.numFailedTests) {
failedObjects.forEach((fail) => {
console.log(`${colors.red(`${fail.numFailingTests} tests failed`)} in '${fail.testFilePath}'`)
})
}
}
}
module.exports = CustomReporter