-
Notifications
You must be signed in to change notification settings - Fork 251
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
fix(JestTestRunner): run jest with --findRelatedTests #1235
Changes from 8 commits
202f7d8
eb97511
d8a0f6c
604ce6e
87bb365
8e64e42
bff462e
1d9e7f6
1de852f
6070dd7
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,12 +1,13 @@ | ||
import { getLogger } from 'stryker-api/logging'; | ||
import { RunnerOptions, RunResult, TestRunner, RunStatus, TestResult, TestStatus } from 'stryker-api/test_runner'; | ||
import { RunnerOptions, RunResult, TestRunner, RunStatus, TestResult, TestStatus, RunOptions } from 'stryker-api/test_runner'; | ||
import * as jest from 'jest'; | ||
import JestTestAdapterFactory from './jestTestAdapters/JestTestAdapterFactory'; | ||
|
||
export default class JestTestRunner implements TestRunner { | ||
private readonly log = getLogger(JestTestRunner.name); | ||
private readonly jestConfig: jest.Configuration; | ||
private readonly processEnvRef: NodeJS.ProcessEnv; | ||
private readonly enableFindRelatedTests: boolean; | ||
|
||
public constructor(options: RunnerOptions, processEnvRef?: NodeJS.ProcessEnv) { | ||
// Make sure process can be mocked by tests by passing it in the constructor | ||
|
@@ -15,19 +16,31 @@ export default class JestTestRunner implements TestRunner { | |
// Get jest configuration from stryker options and assign it to jestConfig | ||
this.jestConfig = options.strykerOptions.jest.config; | ||
|
||
// Get enableFindRelatedTests from stryker jest options or default to true | ||
this.enableFindRelatedTests = options.strykerOptions.jest.enableFindRelatedTests; | ||
if (this.enableFindRelatedTests === undefined) { | ||
this.enableFindRelatedTests = true; | ||
} | ||
|
||
if (this.enableFindRelatedTests) { | ||
this.log.debug('Running jest with --findRelatedTests flag. Set jest.enableFindRelatedTests to false to run all tests on every mutant.'); | ||
} else { | ||
this.log.debug('Running jest without --findRelatedTests flag. Set jest.enableFindRelatedTests to true to run only relevant tests on every mutant.'); | ||
} | ||
|
||
// basePath will be used in future releases of Stryker as a way to define the project root | ||
// Default to process.cwd when basePath is not set for now, should be removed when issue is solved | ||
// https://github.com/stryker-mutator/stryker/issues/650 | ||
this.jestConfig.rootDir = options.strykerOptions.basePath || process.cwd(); | ||
this.log.debug(`Project root is ${this.jestConfig.rootDir}`); | ||
} | ||
|
||
public async run(): Promise<RunResult> { | ||
public async run(options?: RunOptions): Promise<RunResult> { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. I think I initially did that because tests started failing and I was unsure whether or not running without There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Yeah, this is great. We have |
||
this.setNodeEnv(); | ||
|
||
const jestTestRunner = JestTestAdapterFactory.getJestTestAdapter(); | ||
|
||
const { results } = await jestTestRunner.run(this.jestConfig, process.cwd()); | ||
const { results } = await jestTestRunner.run(this.jestConfig, process.cwd(), this.enableFindRelatedTests && options ? options.mutatedFileName : undefined); | ||
|
||
// Get the non-empty errorMessages from the jest RunResult, it's safe to cast to Array<string> here because we filter the empty error messages | ||
const errorMessages = results.testResults.map((testSuite: jest.TestResult) => testSuite.failureMessage).filter(errorMessage => (errorMessage)) as string[]; | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,5 +1,5 @@ | ||
import { RunResult } from 'jest'; | ||
|
||
export default interface JestTestAdapter { | ||
run(config: object, projectRoot: string): Promise<RunResult>; | ||
run(config: object, projectRoot: string, fileNameUnderTest?: string): Promise<RunResult>; | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -9,6 +9,7 @@ describe('JestPromiseTestAdapter', () => { | |
let runCLIStub: sinon.SinonStub; | ||
|
||
const projectRoot = '/path/to/project'; | ||
const fileNameUnderTest = '/path/to/file'; | ||
const jestConfig: any = { rootDir: projectRoot }; | ||
|
||
beforeEach(() => { | ||
|
@@ -37,6 +38,18 @@ describe('JestPromiseTestAdapter', () => { | |
}, [projectRoot])); | ||
}); | ||
|
||
it('should call the runCLI method with the --findRelatedTests flag', async () => { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Great test! |
||
await jestPromiseTestAdapter.run(jestConfig, projectRoot, fileNameUnderTest); | ||
|
||
assert(runCLIStub.calledWith({ | ||
_: [fileNameUnderTest], | ||
config: JSON.stringify({ rootDir: projectRoot, reporters: [] }), | ||
findRelatedTests: true, | ||
runInBand: true, | ||
silent: true | ||
}, [projectRoot])); | ||
}); | ||
|
||
it('should call the runCLI method and return the test result', async () => { | ||
const result = await jestPromiseTestAdapter.run(jestConfig, projectRoot); | ||
|
||
|
@@ -50,6 +63,21 @@ describe('JestPromiseTestAdapter', () => { | |
}); | ||
}); | ||
|
||
it('should call the runCLI method and return the test result when run with --findRelatedTests flag', async () => { | ||
const result = await jestPromiseTestAdapter.run(jestConfig, projectRoot, fileNameUnderTest); | ||
|
||
expect(result).to.deep.equal({ | ||
config: { | ||
nicojs marked this conversation as resolved.
Show resolved
Hide resolved
|
||
_: [fileNameUnderTest], | ||
config: JSON.stringify({ rootDir: projectRoot, reporters: [] }), | ||
findRelatedTests: true, | ||
runInBand: true, | ||
silent: true | ||
}, | ||
result: 'testResult' | ||
}); | ||
}); | ||
|
||
it('should trace log a message when jest is invoked', async () => { | ||
await jestPromiseTestAdapter.run(jestConfig, projectRoot); | ||
|
||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Maybe we can log on debug what we are doing with this setting?