From 012e9ca7d03e39e6832f9f40087ec53d6ccc2728 Mon Sep 17 00:00:00 2001 From: Rhys Evans Date: Sun, 27 Oct 2024 17:39:50 +0000 Subject: [PATCH] fix: clearHistory() can deal with unmatched calls Also adds some long overdue tests --- packages/fetch-mock/src/CallHistory.ts | 6 +++- .../src/__tests__/CallHistory.test.js | 33 ++++++++++++++++++- 2 files changed, 37 insertions(+), 2 deletions(-) diff --git a/packages/fetch-mock/src/CallHistory.ts b/packages/fetch-mock/src/CallHistory.ts index 27023654..d796ba13 100644 --- a/packages/fetch-mock/src/CallHistory.ts +++ b/packages/fetch-mock/src/CallHistory.ts @@ -55,7 +55,11 @@ class CallHistory { } clear() { - this.callLogs.forEach(({ route }) => route.reset()); + this.callLogs.forEach(({ route }) => { + if (route) { + route.reset(); + } + }); this.callLogs = []; } diff --git a/packages/fetch-mock/src/__tests__/CallHistory.test.js b/packages/fetch-mock/src/__tests__/CallHistory.test.js index adacddf2..0727d3b1 100644 --- a/packages/fetch-mock/src/__tests__/CallHistory.test.js +++ b/packages/fetch-mock/src/__tests__/CallHistory.test.js @@ -11,7 +11,38 @@ describe('CallHistory', () => { const fetchTheseUrls = (...urls) => Promise.all(urls.map((url) => fm.fetchHandler(url))); - describe('helper methods', () => { + describe('clear', () => { + it('should clear all call logs', async () => { + fm.route('http://a.com', 200).route('http://b.com', 200); + fm.fetchHandler('http://a.com'); + fm.fetchHandler('http://b.com'); + + expect(fm.callHistory.callLogs.length).toEqual(2); + fm.callHistory.clear(); + expect(fm.callHistory.callLogs.length).toEqual(0); + }); + it('should clear counter in routes that are set to only respond a set number of times', async () => { + fm.once('http://a.com', 200); + fm.fetchHandler('http://a.com'); + fm.callHistory.clear(); + await expect(fm.fetchHandler('http://a.com')).resolves.not.toThrow(); + }); + it('should not error if there are unmatched calls', async () => { + try { + await fm.fetchHandler('https://example.com'); + } catch { + expect(() => fm.callHistory.clear()).not.toThrow(); // Error + } + }); + + it('is aliased to fetchMock.clearHistory()', async () => { + vi.spyOn(fm.callHistory, 'clear'); + fm.clearHistory(); + expect(fm.callHistory.clear).toHaveBeenCalled(); + fm.callHistory.clear.mockRestore(); + }); + }); + describe('inspecting call history methods', () => { describe('called()', () => { it('returns a suitable boolean', () => { fm.catch();