From 030e53c266aa4c4467cb4fb99dcceeb34881f6c4 Mon Sep 17 00:00:00 2001 From: Carl-Erik Kopseng Date: Mon, 26 Aug 2024 09:59:14 +0200 Subject: [PATCH 1/2] Fix toString() output The output when just inheriting was function() { [native code] } vs function Date() { [native code] } in the real Date object. I had to make a choice between having the same function identity and function output and opted for the latter, since that is what the mother sinon project targets. --- src/fake-timers-src.js | 4 ++++ test/fake-timers-test.js | 4 ++-- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/src/fake-timers-src.js b/src/fake-timers-src.js index c389223..94d2b4f 100644 --- a/src/fake-timers-src.js +++ b/src/fake-timers-src.js @@ -456,6 +456,10 @@ function withGlobal(_global) { }; } + ClockDate.toString = function toString() { + return NativeDate.toString(); + }; + // noinspection UnnecessaryLocalVariableJS /** * A normal Class constructor cannot be called without `new`, but Date can, so we need diff --git a/test/fake-timers-test.js b/test/fake-timers-test.js index c876ab7..321a9d4 100644 --- a/test/fake-timers-test.js +++ b/test/fake-timers-test.js @@ -3358,8 +3358,8 @@ describe("FakeTimers", function () { }); }); - it("mirrors toString", function () { - assert.same(this.clock.Date.toString, Date.toString); + it("mirrors toString output", function () { + assert.same(this.clock.Date.toString(), Date.toString()); }); }); From 9fdc01e9904521e701f6674b935eefe2206af47c Mon Sep 17 00:00:00 2001 From: Carl-Erik Kopseng Date: Mon, 26 Aug 2024 11:18:49 +0200 Subject: [PATCH 2/2] Add a missing test on using timers not present on a custom global This was present in Sinon and should be here as well --- src/fake-timers-src.js | 5 ++++- test/fake-timers-test.js | 10 ++++++++-- 2 files changed, 12 insertions(+), 3 deletions(-) diff --git a/src/fake-timers-src.js b/src/fake-timers-src.js index 94d2b4f..b2f7e8d 100644 --- a/src/fake-timers-src.js +++ b/src/fake-timers-src.js @@ -1057,6 +1057,9 @@ function withGlobal(_global) { if (isPresent.setImmediate) { timers.setImmediate = _global.setImmediate; + } + + if (isPresent.clearImmediate) { timers.clearImmediate = _global.clearImmediate; } @@ -1077,7 +1080,7 @@ function withGlobal(_global) { } if (isPresent.queueMicrotask) { - timers.queueMicrotask = true; + timers.queueMicrotask = _global.queueMicrotask; } if (isPresent.cancelAnimationFrame) { diff --git a/test/fake-timers-test.js b/test/fake-timers-test.js index 321a9d4..8d130df 100644 --- a/test/fake-timers-test.js +++ b/test/fake-timers-test.js @@ -6069,12 +6069,18 @@ describe("missing timers", function () { }); it(`should ignore timers in toFake that are not present in "global" when passed the ignore flag: [${timer}]`, function () { - //refute.exception(function () { FakeTimers.withGlobal({ Date }).install({ ignoreMissingTimers: true, toFake: [timer], }); - //}); }); }); + + it("should throw on trying to use standard timers that are not present on the custom global", function () { + assert.exception(function () { + FakeTimers.withGlobal({ setTimeout, Date }).install({ + toFake: ["setInterval"], + }); + }, /cannot be faked: 'setInterval'/); + }); });