Skip to content

Commit

Permalink
Merge pull request #204 from JohanBrorson/configurable-testsuite-prop…
Browse files Browse the repository at this point in the history
…erties-dir

feat: make the test suite properties path configurable
  • Loading branch information
palmerj3 authored Apr 5, 2022
2 parents e7321b4 + a15a3fb commit 339558c
Show file tree
Hide file tree
Showing 7 changed files with 118 additions and 7 deletions.
6 changes: 4 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ jest --ci --reporters=default --reporters=jest-junit
```

## Usage as testResultsProcessor (deprecated)
The support for `testResultsProcessor` is only kept for [legacy reasons][test-results-processor] and might be removed in the future.
The support for `testResultsProcessor` is only kept for [legacy reasons][test-results-processor] and might be removed in the future.
You should therefore prefer to configure `jest-junit` as a _reporter_.

Should you still want to, add the following entry to your jest config:
Expand Down Expand Up @@ -72,8 +72,10 @@ Reporter options should also be strings exception for suiteNameTemplate, classNa
| `JEST_JUNIT_INCLUDE_CONSOLE_OUTPUT` | `includeConsoleOutput` | Adds console output to any testSuite that generates stdout during a test run. | `false` | N/A
| `JEST_JUNIT_INCLUDE_SHORT_CONSOLE_OUTPUT` | `includeShortConsoleOutput` | Adds short console output (only message value) to any testSuite that generates stdout during a test run. | `false` | N/A
| `JEST_JUNIT_REPORT_TEST_SUITE_ERRORS` | `reportTestSuiteErrors` | Reports test suites that failed to execute altogether as `error`. _Note:_ since the suite name cannot be determined from files that fail to load, it will default to file path.| `false` | N/A
| `JEST_JUNIT_NO_STACK_TRACE` | `noStackTrace` | Omit stack traces from test failure reports, similar to `jest --noStackTrace` | `false` | N/A
| `JEST_JUNIT_NO_STACK_TRACE` | `noStackTrace` | Omit stack traces from test failure reports, similar to `jest --noStackTrace` | `false` | N/A
| `JEST_USE_PATH_FOR_SUITE_NAME` | `usePathForSuiteName` | **DEPRECATED. Use `suiteNameTemplate` instead.** Use file path as the `name` attribute of `<testsuite>` | `"false"` | N/A
| `JEST_JUNIT_TEST_SUITE_PROPERTIES_JSON_FILE` | `testSuitePropertiesFile` | Name of the custom testsuite properties file | `"junitProperties.js"` | N/A
| `JEST_JUNIT_TEST_SUITE_PROPERTIES_DIR` | `testSuitePropertiesDirectory` | Location of the custom testsuite properties file | `process.cwd()` | N/A


You can configure these options via the command line as seen below:
Expand Down
48 changes: 48 additions & 0 deletions __tests__/buildJsonResults.test.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
'use strict';

const fs = require('fs');
const slash = require('slash');
const buildJsonResults = require('../utils/buildJsonResults');
const constants = require('../constants/index');
Expand All @@ -8,7 +9,13 @@ let jsonResults;
let ignoreJunitErrors = false;

describe('buildJsonResults', () => {
beforeEach(() => {
jest.spyOn(fs, 'existsSync');
})

afterEach(() => {
jest.restoreAllMocks();

if (ignoreJunitErrors !== true) {
// Verify each tests JSON output results in a
// compliant junit.xml file based on __tests__/lib/junit.xsd (jenkins xsd)
Expand Down Expand Up @@ -396,4 +403,45 @@ describe('buildJsonResults', () => {

expect(jsonResults.testsuites[1].testsuite[2]['system-out']).not.toBeDefined();
});

it('should get custom testsuite properties from specified file path', () => {
const noFailingTestsReport = require('../__mocks__/no-failing-tests.json');
jest.mock(
'/path/to/properties.js',
() => {
return jest.fn(() => {
return { 'best-tester': 'Johan' };
});
},
{ virtual: true },
);

fs.existsSync.mockReturnValue(true);

const options = {
...constants.DEFAULT_OPTIONS,
testSuitePropertiesFile: 'properties.js',
testSuitePropertiesDirectory: '<rootDir>',
};

jsonResults = buildJsonResults(
noFailingTestsReport,
'/',
options,
'/path/to',
);

expect(jsonResults.testsuites[1].testsuite[1].properties).toEqual(
expect.arrayContaining([
{
property: expect.objectContaining({
_attr: expect.objectContaining({
name: 'best-tester',
value: 'Johan',
}),
}),
},
]),
);
});
});
34 changes: 34 additions & 0 deletions __tests__/getTestSuitePropertiesPath.test.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
const path = require('path');
const getTestSuitePropertiesPath = require('../utils/getTestSuitePropertiesPath');

jest.mock('path', () => {
return {
...jest.requireActual('path'),
join: (...paths) => {
return paths.join('/');
},
resolve: (...paths) => {
return `/absolute/${paths.join('/')}`
}
};
});

const options = {
testSuitePropertiesFile: 'properties.js',
testSuitePropertiesDirectory: '<rootDir>',
};

describe('getTestSuitePropertiesPath', () => {
it('should replace <rootDir> in test suite properties path', () => {
const testSuitePropertiesPath = getTestSuitePropertiesPath(
options,
'path/to',
);
expect(testSuitePropertiesPath).toEqual('/absolute/path/to/properties.js');
});

it('should not replace <rootDir> in test suite properties path when rootDir is not set', () => {
const testSuitePropertiesPath = getTestSuitePropertiesPath(options);
expect(testSuitePropertiesPath).toEqual('/absolute/<rootDir>/properties.js');
});
});
6 changes: 4 additions & 2 deletions constants/index.js
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ module.exports = {
JEST_JUNIT_REPORT_TEST_SUITE_ERRORS: 'reportTestSuiteErrors',
JEST_JUNIT_NO_STACK_TRACE: "noStackTrace",
JEST_USE_PATH_FOR_SUITE_NAME: 'usePathForSuiteName',
JEST_JUNIT_TEST_SUITE_PROPERTIES_JSON_FILE: 'testSuitePropertiesFile'
JEST_JUNIT_TEST_SUITE_PROPERTIES_JSON_FILE: 'testSuitePropertiesFile',
JEST_JUNIT_TEST_SUITE_PROPERTIES_DIR: 'testSuitePropertiesDirectory',
},
DEFAULT_OPTIONS: {
suiteName: 'jest tests',
Expand All @@ -34,7 +35,8 @@ module.exports = {
includeShortConsoleOutput: 'false',
reportTestSuiteErrors: 'false',
noStackTrace: 'false',
testSuitePropertiesFile: 'junitProperties.js'
testSuitePropertiesFile: 'junitProperties.js',
testSuitePropertiesDirectory: process.cwd(),
},
SUITENAME_VAR: 'suitename',
CLASSNAME_VAR: 'classname',
Expand Down
7 changes: 6 additions & 1 deletion index.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,12 @@ const processor = (report, reporterOptions = {}, jestRootDir = null) => {
t.console = consoleBuffer[t.testFilePath];
});

const jsonResults = buildJsonResults(report, fs.realpathSync(process.cwd()), options);
const jsonResults = buildJsonResults(
report,
fs.realpathSync(process.cwd()),
options,
jestRootDir
);

let outputPath = getOutputPath(options, jestRootDir);

Expand Down
8 changes: 6 additions & 2 deletions utils/buildJsonResults.js
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ const stripAnsi = require('strip-ansi');
const constants = require('../constants/index');
const path = require('path');
const fs = require('fs');
const getTestSuitePropertiesPath = require('./getTestSuitePropertiesPath');

// Wrap the varName with template tags
const toTemplateTag = function (varName) {
Expand Down Expand Up @@ -46,9 +47,12 @@ const addErrorTestResult = function (suite) {
})
}

module.exports = function (report, appDirectory, options) {
module.exports = function (report, appDirectory, options, rootDir = null) {
// Check if there is a junitProperties.js (or whatever they called it)
const junitSuitePropertiesFilePath = path.join(process.cwd(), options.testSuitePropertiesFile);
const junitSuitePropertiesFilePath = getTestSuitePropertiesPath(
options,
rootDir,
);
let ignoreSuitePropertiesCheck = !fs.existsSync(junitSuitePropertiesFilePath);

// If the usePathForSuiteName option is true and the
Expand Down
16 changes: 16 additions & 0 deletions utils/getTestSuitePropertiesPath.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
const path = require('path');
const replaceRootDirInOutput = require('./getOptions').replaceRootDirInOutput;

module.exports = (options, rootDir = null) => {
const testSuitePropertiesPath = replaceRootDirInOutput(
rootDir,
path.join(
options.testSuitePropertiesDirectory,
options.testSuitePropertiesFile,
),
);

return path.isAbsolute(testSuitePropertiesPath)
? testSuitePropertiesPath
: path.resolve(testSuitePropertiesPath);
};

0 comments on commit 339558c

Please sign in to comment.