Skip to content

Commit

Permalink
fix: use typeof assertion instead of instanceof to differentiate Mode…
Browse files Browse the repository at this point in the history
…rnFakeTimers and LegacyFakeTimers methods

Closes jestjs#11660 jestjs#11767 jestjs#11662
  • Loading branch information
minijus committed Oct 10, 2021
1 parent 03f4a69 commit 955b9e2
Showing 1 changed file with 15 additions and 7 deletions.
22 changes: 15 additions & 7 deletions packages/jest-runtime/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -30,7 +30,7 @@ import type {
Module,
ModuleWrapper,
} from '@jest/environment';
import {LegacyFakeTimers, ModernFakeTimers} from '@jest/fake-timers';
import type {LegacyFakeTimers, ModernFakeTimers} from '@jest/fake-timers';
import type * as JestGlobals from '@jest/globals';
import type {SourceMapRegistry} from '@jest/source-map';
import type {RuntimeTransformResult, V8CoverageResult} from '@jest/test-result';
Expand Down Expand Up @@ -1961,8 +1961,11 @@ export default class Runtime {
getRealSystemTime: () => {
const fakeTimers = _getFakeTimers();

if (fakeTimers instanceof ModernFakeTimers) {
return fakeTimers.getRealSystemTime();
if (
typeof (fakeTimers as ModernFakeTimers).getRealSystemTime ===
'function'
) {
return (fakeTimers as ModernFakeTimers).getRealSystemTime();
} else {
throw new TypeError(
'getRealSystemTime is not available when not using modern timers',
Expand All @@ -1982,8 +1985,11 @@ export default class Runtime {
runAllImmediates: () => {
const fakeTimers = _getFakeTimers();

if (fakeTimers instanceof LegacyFakeTimers) {
fakeTimers.runAllImmediates();
if (
typeof (fakeTimers as LegacyFakeTimers<unknown>).runAllImmediates ===
'function'
) {
(fakeTimers as LegacyFakeTimers<unknown>).runAllImmediates();
} else {
throw new TypeError(
'runAllImmediates is not available when using modern timers',
Expand All @@ -1998,8 +2004,10 @@ export default class Runtime {
setSystemTime: (now?: number | Date) => {
const fakeTimers = _getFakeTimers();

if (fakeTimers instanceof ModernFakeTimers) {
fakeTimers.setSystemTime(now);
if (
typeof (fakeTimers as ModernFakeTimers).setSystemTime === 'function'
) {
(fakeTimers as ModernFakeTimers).setSystemTime(now);
} else {
throw new TypeError(
'setSystemTime is not available when not using modern timers',
Expand Down

0 comments on commit 955b9e2

Please sign in to comment.