From 0cd00e68cb8a0a2e4cbe64c2a655bd142e9a5f83 Mon Sep 17 00:00:00 2001 From: kwasniew Date: Tue, 21 May 2024 12:18:53 +0200 Subject: [PATCH 1/2] test: aborted requests should not trigger error state --- src/index.test.ts | 20 ++++++++++++++++++++ 1 file changed, 20 insertions(+) diff --git a/src/index.test.ts b/src/index.test.ts index 79eb05f..6fd48dd 100644 --- a/src/index.test.ts +++ b/src/index.test.ts @@ -613,6 +613,7 @@ test('Should abort previous request', async () => { appName: 'web', }; const client = new UnleashClient(config); + await client.start(); client.updateContext({ userId: '123' }); // abort 1 client.updateContext({ userId: '456' }); // abort 2 @@ -622,6 +623,25 @@ test('Should abort previous request', async () => { abortSpy.mockRestore(); }); +test('Should not trigger error on abort', async () => { + fetchMock.mockResponse(JSON.stringify(data)); + + const config: IConfig = { + url: 'http://localhost/test', + clientKey: '12', + appName: 'web', + }; + const client = new UnleashClient(config); + client.on(EVENTS.ERROR, (e: any) => { + throw new Error('abort should not trigger error'); + }); + + await client.start(); + + fetchMock.mockAbort(); + await client.updateContext({ userId: '789' }); +}); + test.each([400, 401, 403, 404, 429, 500, 502, 503])( 'Should publish error when fetch receives a %d error', async (errorCode) => { From 509938a7777ef4fc860fb0a7da9fc8003734dca4 Mon Sep 17 00:00:00 2001 From: kwasniew Date: Tue, 21 May 2024 12:20:13 +0200 Subject: [PATCH 2/2] test: aborted requests should not trigger error state --- src/index.test.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/index.test.ts b/src/index.test.ts index 6fd48dd..fcb8a00 100644 --- a/src/index.test.ts +++ b/src/index.test.ts @@ -632,7 +632,7 @@ test('Should not trigger error on abort', async () => { appName: 'web', }; const client = new UnleashClient(config); - client.on(EVENTS.ERROR, (e: any) => { + client.on(EVENTS.ERROR, () => { throw new Error('abort should not trigger error'); });