A Jest reporter that creates compatible junit xml files
yarn add --dev jest-junitIn an upcoming major version 5.x jest-junit will no longer function as a testResultProcessor. It will only work as a jest reporter. See the docs just below this for how to transition your project.
In your jest config add the following entry:
{
"reporters": [ "default", "jest-junit" ]
}Then simply run:
jestFor your Continuous Integration you can simply do:
jest --ci --reporters=default --reporters=jest-junitIn your jest config add the following entry:
{
"testResultsProcessor": "jest-junit"
}Then simply run:
jestFor your Continuous Integration you can simply do:
jest --ci --testResultsProcessor="jest-junit"jest-junit offers seven configurations based on environment variables or a jest-junit key defined in package.json or a reporter option.
Environement variable and package.json configuration should be strings.
Reporter options should also be strings exception for suiteNameTemplate, classNameTemplate, titleNameTemplate that can also accept a function returning a string.
| Variable Name | Description | Default | Possible Injection Values |
|---|---|---|---|
JEST_SUITE_NAME |
name attribute of <testsuites> |
"jest tests" |
N/A |
JEST_JUNIT_OUTPUT |
File path to save the output. | "./junit.xml" |
N/A |
JEST_JUNIT_OUTPUT_DIR |
Directory to save the output. | null |
N/A |
JEST_JUNIT_OUTPUT_NAME |
File name for the output. | "./junit.xml" |
N/A |
JEST_JUNIT_SUITE_NAME |
Template string for name attribute of the <testsuite>. |
"{title}" |
{title}, {filepath}, {filename}, {displayName} |
JEST_JUNIT_CLASSNAME |
Template string for the classname attribute of <testcase>. |
"{classname} {title}" |
{classname}, {title}, {filepath}, {filename}, {displayName} |
JEST_JUNIT_TITLE |
Template string for the name attribute of <testcase>. |
"{classname} {title}" |
{classname}, {title}, {filepath}, {filename}, {displayName} |
JEST_JUNIT_ANCESTOR_SEPARATOR |
Character(s) used to join the describe blocks. |
" " |
N/A |
JEST_USE_PATH_FOR_SUITE_NAME |
DEPRECATED. Use suiteNameTemplate instead. Use file path as the name attribute of <testsuite> |
"false" |
N/A |
You can configure these options via the command line as seen below:
JEST_SUITE_NAME="Jest JUnit Unit Tests" JEST_JUNIT_OUTPUT="./artifacts/junit.xml" jestOr you can also define a jest-junit key in your package.json. All are string values.
{
...
"jest-junit": {
"suiteName": "jest tests",
"outputDirectory": ".",
"outputName": "./junit.xml",
"classNameTemplate": "{classname}-{title}",
"titleTemplate": "{classname}-{title}",
"ancestorSeparator": " › ",
"usePathForSuiteName": "true"
}
}
Or you can define your options in your reporter configuration.
// jest.config.js
{
reporters: [
"default",
[ "jest-junit", { suiteName: "jest tests" } ]
]
}If using the usePathForSuiteName and suiteNameTemplate, the usePathForSuiteName value will take precedence. ie: if usePathForSuiteName=true and suiteNameTemplate="{filename}", the filepath will be used as the name attribute of the <testsuite> in the rendered jest-junit.xml).
Below are some example configuration values and the rendered .xml to created by jest-junit.
The following test defined in the file /__tests__/addition.test.js will be used for all examples:
describe('addition', () => {
describe('positive numbers', () => {
it('should add up', () => {
expect(1 + 2).toBe(3);
});
});
});The default output:
<testsuites name="jest tests">
<testsuite name="addition" tests="1" errors="0" failures="0" skipped="0" timestamp="2017-07-13T09:42:28" time="0.161">
<testcase classname="addition positive numbers should add up" name="addition positive numbers should add up" time="0.004">
</testcase>
</testsuite>
</testsuites>Using the classNameTemplate and titleTemplate:
JEST_JUNIT_CLASSNAME="{classname}" JEST_JUNIT_TITLE="{title}" jestrenders
<testsuites name="jest tests">
<testsuite name="addition" tests="1" errors="0" failures="0" skipped="0" timestamp="2017-07-13T09:45:42" time="0.154">
<testcase classname="addition positive numbers" name="should add up" time="0.005">
</testcase>
</testsuite>
</testsuites>Using the ancestorSeparator:
JEST_JUNIT_ANCESTOR_SEPARATOR=" › " jestrenders
<testsuites name="jest tests">
<testsuite name="addition" tests="1" errors="0" failures="0" skipped="0" timestamp="2017-07-13T09:47:12" time="0.162">
<testcase classname="addition › positive numbers should add up" name="addition › positive numbers should add up" time="0.004">
</testcase>
</testsuite>
</testsuites>Using the suiteNameTemplate:
JEST_JUNIT_SUIT_NAME ="{filename}" jest<testsuites name="jest tests">
<testsuite name="addition.test.js" tests="1" errors="0" failures="0" skipped="0" timestamp="2017-07-13T09:42:28" time="0.161">
<testcase classname="addition positive numbers should add up" name="addition positive numbers should add up" time="0.004">
</testcase>
</testsuite>
</testsuites>Using classNameTemplate as a function in reporter options
// jest.config.js
{
reporters: [
"default",
[
"jest-junit",
{
classNameTemplate: (vars) => {
return vars.classname.toUpperCase();
}
}
]
]
}renders
<testsuites name="jest tests">
<testsuite name="addition" tests="1" errors="0" failures="0" skipped="0" timestamp="2017-07-13T09:42:28" time="0.161">
<testcase classname="ADDITION POSITIVE NUMBERS" name="addition positive numbers should add up" time="0.004">
</testcase>
</testsuite>
</testsuites>