Skip to content

Commit

Permalink
fix: jest-circus shares events among imports #11483
Browse files Browse the repository at this point in the history
  • Loading branch information
satanTime committed Sep 11, 2022
1 parent 052aa67 commit eca5044
Show file tree
Hide file tree
Showing 5 changed files with 47 additions and 6 deletions.
1 change: 1 addition & 0 deletions packages/jest-circus/src/__mocks__/testUtils.ts
Original file line number Diff line number Diff line change
Expand Up @@ -49,6 +49,7 @@ export const runTest = (source: string) => {
const testEventHandler = require('${TEST_EVENT_HANDLER_PATH}').default;
const addEventHandler = require('${CIRCUS_STATE_PATH}').addEventHandler;
const removeEventHandler = require('${CIRCUS_STATE_PATH}').removeEventHandler;
addEventHandler(testEventHandler);
${source};
Expand Down
25 changes: 25 additions & 0 deletions packages/jest-circus/src/__tests__/eventHandler.test.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
/**
* Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*/

// addEventHandler and removeEventHandler are provided in the ./index
import {addEventHandler, removeEventHandler} from '../index';
// dispatch comes from the ./state
import {dispatch} from '../state';

test('addEventHandler and removeEventHandler control handlers', async () => {
const spy = jest.fn();

addEventHandler(spy);
expect(spy).not.toHaveBeenCalledWith({name: 'unknown1'}, expect.anything());
await dispatch({name: 'unknown1' as any});
expect(spy).toHaveBeenCalledWith({name: 'unknown1'}, expect.anything());

removeEventHandler(spy);
expect(spy).not.toHaveBeenCalledWith({name: 'unknown2'}, expect.anything());
await dispatch({name: 'unknown2' as any});
expect(spy).not.toHaveBeenCalledWith({name: 'unknown2'}, expect.anything());
});
8 changes: 7 additions & 1 deletion packages/jest-circus/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,13 @@ import {bind as bindEach} from 'jest-each';
import {ErrorWithStack, convertDescriptorToString, isPromise} from 'jest-util';
import {dispatchSync} from './state';

export {setState, getState, resetState} from './state';
export {
setState,
getState,
resetState,
addEventHandler,
removeEventHandler,
} from './state';
export {default as run} from './run';

type THook = (fn: Circus.HookFn, timeout?: number) => void;
Expand Down
17 changes: 12 additions & 5 deletions packages/jest-circus/src/state.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@
import type {Circus} from '@jest/types';
import eventHandler from './eventHandler';
import formatNodeAssertErrors from './formatNodeAssertErrors';
import {STATE_SYM} from './types';
import {EVENT_HANDLERS, STATE_SYM} from './types';
import {makeDescribe} from './utils';

const eventHandlers: Array<Circus.EventHandler> = [
global[EVENT_HANDLERS] = global[EVENT_HANDLERS] || [
eventHandler,
formatNodeAssertErrors,
];
Expand Down Expand Up @@ -49,17 +49,24 @@ export const setState = (state: Circus.State): Circus.State =>
/* eslint-enable */

export const dispatch = async (event: Circus.AsyncEvent): Promise<void> => {
for (const handler of eventHandlers) {
for (const handler of global[EVENT_HANDLERS]) {
await handler(event, getState());
}
};

export const dispatchSync = (event: Circus.SyncEvent): void => {
for (const handler of eventHandlers) {
for (const handler of global[EVENT_HANDLERS]) {
handler(event, getState());
}
};

export const addEventHandler = (handler: Circus.EventHandler): void => {
eventHandlers.push(handler);
global[EVENT_HANDLERS].push(handler);
};

export const removeEventHandler = (handler: Circus.EventHandler): void => {
const index = global[EVENT_HANDLERS].lastIndexOf(handler);
if (index !== -1) {
global[EVENT_HANDLERS].splice(index, 1);
}
};
2 changes: 2 additions & 0 deletions packages/jest-circus/src/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ export const STATE_SYM = Symbol('JEST_STATE_SYMBOL');
export const RETRY_TIMES = Symbol.for('RETRY_TIMES');
// To pass this value from Runtime object to state we need to use global[sym]
export const TEST_TIMEOUT_SYMBOL = Symbol.for('TEST_TIMEOUT_SYMBOL');
export const EVENT_HANDLERS = Symbol.for('EVENT_HANDLERS');
export const LOG_ERRORS_BEFORE_RETRY = Symbol.for('LOG_ERRORS_BEFORE_RETRY');

declare global {
Expand All @@ -20,6 +21,7 @@ declare global {
[STATE_SYM]: Circus.State;
[RETRY_TIMES]: string;
[TEST_TIMEOUT_SYMBOL]: number;
[EVENT_HANDLERS]: Array<Circus.EventHandler>;
[LOG_ERRORS_BEFORE_RETRY]: boolean;
}
}
Expand Down

0 comments on commit eca5044

Please sign in to comment.