jest-sonar-reporter is a custom results processor for Jest. The processor converts Jest's output into Sonar's generic test data format.
This is fork from 3dmind jest-sonar-reporter with some small fixes.
- Fixed error with strange characters (for example
expect(�[107mrec)
) - SQ does not work with these characters. - Previously in report file the path to checked file was like
"/usr/src/app/src/modules/<path>"
so I change file path to"src/modules/<path>"
- Fixed error with recursive creating folder (if your directory for reports is like
<root>/folder/anotherFolder/reports
)
Using npm:
$ npm i -D pruchay/jest-sonar-reporter
Using yarn:
$ yarn add -D pruchay/jest-sonar-reporter
Configure Jest in your package.json
to use jest-sonar-reporter
as a custom results processor.
{
"jest": {
"testResultsProcessor": "jest-sonar-reporter"
}
}
Looks like Jest try to run coverage report even if I don't ask him (more in this issue).
Configure Sonar to import the test results. Add the sonar.testExecutionReportPaths
property to your
sonar-project.properties
file.
sonar.javascript.lcov.reportPaths=coverage/lcov.info
sonar.testExecutionReportPaths=coverage/test-report.xml
To customize the reporter you can use package.json
to store the configuration.
Create a jestSonar
entry like this:
{
"jestSonar": {}
}
You can customize the following options:
reportPath
This will specify the path to put the report in.reportFile
This will specify the file name of the report.indent
This will specify the indentation to format the report.
{
"jestSonar": {
"reportPath": "reports",
"reportFile": "test-reporter.xml",
"indent": 4
}
}
Important: Don't forget to update
sonar.testExecutionReportPaths
when you use a custom path and file name.
Sonarqube 5.6.x does not support Generic Test Data however it has a Generic Test Coverage plugin which offers similar functionality.
If you have the plugin installed on Sonarqube, you can configure this reporter to produce files in supported format.
{
"jestSonar": {
"sonar56x": true
}
}
Configure Sonar to import the test results. Add the sonar.genericcoverage.unitTestReportPaths
property to your
sonar-project.properties
file.
sonar.genericcoverage.unitTestReportPaths=test-report.xml
To support different environments add the env
property to the configuration and overwrite the value of the option you want to modify for the specific environment.
You can overwrite the following configuration options: reportPath
, reportFile
, indent
, sonar56x
For example: Overwrite the path were the report will be stored.
{
"jestSonar": {
"reportPath": "reports",
"reportFile": "test-reporter.xml",
"indent": 4,
"env": {
"test": {
"reportPath": "reports-test"
}
}
}
}
Use the NODE_ENV
variable to activate the environment specific configuration.
NODE_ENV=test npm run test
- Run Jest to execute your tests with coverage flag (for example
jest --coverage
).
Using npm:
$ npm run test
Using yarn:
$ yarn run test
- Configure your SQ configuration file
For example:
# Source
sonar.sources=src
sonar.exclusions=**/__tests__/**/*
# Unit tests
sonar.tests=src
sonar.test.inclusions=**/__tests__/**/*.test.js
# Test Coverage & Execution
sonar.javascript.lcov.reportPaths=coverage/lcov.info
sonar.testExecutionReportPaths=coverage/test-report.xml
Read official SQ documentation for more information about how to Configure SQ.
- Run sonar-scanner to import the test results.
$ sonar-scanner
This project uses the MIT licence.