From 0bd6bbf06eb15e8157df5d6a7f51e03a170abd69 Mon Sep 17 00:00:00 2001 From: Sean Poulter Date: Tue, 12 Dec 2017 09:08:26 -0500 Subject: [PATCH 1/2] Use all --testPathPattern and CLI args in testPathPattern This fixes #5037. --- packages/jest-cli/src/cli/args.js | 2 +- .../src/__tests__/normalize.test.js | 28 +++++++++++++++++-- packages/jest-config/src/normalize.js | 27 ++++++++---------- types/Argv.js | 2 +- 4 files changed, 39 insertions(+), 20 deletions(-) diff --git a/packages/jest-cli/src/cli/args.js b/packages/jest-cli/src/cli/args.js index c312674a2d9e..4c5bbb06cd28 100644 --- a/packages/jest-cli/src/cli/args.js +++ b/packages/jest-cli/src/cli/args.js @@ -484,7 +484,7 @@ export const options = { description: 'A regexp pattern string that is matched against all tests ' + 'paths before executing the test.', - type: 'string', + type: 'array', }, testRegex: { description: 'The regexp pattern Jest uses to detect test files.', diff --git a/packages/jest-config/src/__tests__/normalize.test.js b/packages/jest-config/src/__tests__/normalize.test.js index 3b8375d42a27..19cbf8d62eb9 100644 --- a/packages/jest-config/src/__tests__/normalize.test.js +++ b/packages/jest-config/src/__tests__/normalize.test.js @@ -1055,18 +1055,32 @@ describe('testPathPattern', () => { describe('--testPathPattern', () => { it('uses testPathPattern if set', () => { - const {options} = normalize(initialOptions, {testPathPattern: 'a/b'}); + const {options} = normalize(initialOptions, {testPathPattern: ['a/b']}); expect(options.testPathPattern).toBe('a/b'); }); it('ignores invalid regular expressions and logs a warning', () => { - const {options} = normalize(initialOptions, {testPathPattern: 'a('}); + const {options} = normalize(initialOptions, {testPathPattern: ['a(']}); expect(options.testPathPattern).toBe(''); expect(console.log.mock.calls[0][0]).toMatchSnapshot(); }); it('escapes Windows path separators', () => { - testWindowsPathSeparator({testPathPattern: 'a\\b'}, 'a\\\\b'); + testWindowsPathSeparator({testPathPattern: ['a\\b']}, 'a\\\\b'); + }); + + it('joins multiple --testPathPatterns if set', () => { + const {options} = normalize(initialOptions, { + testPathPattern: ['a/b', 'c/d'], + }); + expect(options.testPathPattern).toBe('a/b|c/d'); + }); + + it('escapes Windows path separators in multiple args', () => { + testWindowsPathSeparator( + {testPathPattern: ['a\\b', 'c\\d']}, + 'a\\\\b|c\\\\d', + ); }); }); @@ -1095,4 +1109,12 @@ describe('testPathPattern', () => { testWindowsPathSeparator({_: ['a\\b', 'c\\d']}, 'a\\\\b|c\\\\d'); }); }); + + it('joins multiple --testPathPatterns and ', () => { + const {options} = normalize(initialOptions, { + _: ['a', 'b'], + testPathPattern: ['c', 'd'], + }); + expect(options.testPathPattern).toBe('a|b|c|d'); + }); }); diff --git a/packages/jest-config/src/normalize.js b/packages/jest-config/src/normalize.js index 86ce74556f7d..27e6f8909aac 100644 --- a/packages/jest-config/src/normalize.js +++ b/packages/jest-config/src/normalize.js @@ -279,25 +279,22 @@ const normalizeReporters = (options: InitialOptions, basedir) => { }; const buildTestPathPattern = (argv: Argv): string => { + const patterns = []; + + if (argv._) { + patterns.push(...argv._); + } if (argv.testPathPattern) { - if (validatePattern(argv.testPathPattern)) { - return replacePathSepForRegex(argv.testPathPattern); - } else { - showTestPathPatternError(argv.testPathPattern); - } + patterns.push(...argv.testPathPattern); } - if (argv._ && argv._.length) { - const testPathPattern = argv._.map(replacePathSepForRegex).join('|'); - - if (validatePattern(testPathPattern)) { - return testPathPattern; - } else { - showTestPathPatternError(testPathPattern); - } + const testPathPattern = patterns.map(replacePathSepForRegex).join('|'); + if (validatePattern(testPathPattern)) { + return testPathPattern; + } else { + showTestPathPatternError(testPathPattern); + return ''; } - - return ''; }; const showTestPathPatternError = (testPathPattern: string) => { diff --git a/types/Argv.js b/types/Argv.js index 7125a0f75ce9..186b8db2ebde 100644 --- a/types/Argv.js +++ b/types/Argv.js @@ -69,7 +69,7 @@ export type Argv = {| testMatch: Array, testNamePattern: string, testPathIgnorePatterns: Array, - testPathPattern: string, + testPathPattern: Array, testRegex: string, testResultsProcessor: ?string, testRunner: string, From 3a5487762b712431878cdf0cc8ddfd5286174f36 Mon Sep 17 00:00:00 2001 From: Sean Poulter Date: Tue, 12 Dec 2017 09:42:18 -0500 Subject: [PATCH 2/2] Add PR to CHANGELOG.md --- CHANGELOG.md | 2 ++ 1 file changed, 2 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index c44e8246533d..417eda4204c1 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -2,6 +2,8 @@ ### Fixes +* `[jest-config]` Use all `--testPathPattern` and `` args in + `testPathPattern`([#5066](https://github.com/facebook/jest/pull/5066)) * `[jest-cli]` Do not support `--watch` inside non-version-controlled environments ([#5060](https://github.com/facebook/jest/pull/5060)) * `[jest-config]` Escape Windows path separator in testPathPattern CLI arguments