From f9b0ae6c90556304169286f0cfae555c83c7f238 Mon Sep 17 00:00:00 2001 From: Jeffrey Posnick Date: Mon, 17 Dec 2018 15:50:08 -0500 Subject: [PATCH] Adds a fetchDidSucceed callback (#1772) * New fetchDidSucceed callback * Include event to fetchDidSuccess callback * Testing fix. --- .../workbox-core/_private/cacheWrapper.mjs | 4 +- .../workbox-core/_private/fetchWrapper.mjs | 26 +++++++++++- packages/workbox-core/models/pluginEvents.mjs | 1 + .../node/_private/test-fetchWrapper.mjs | 42 +++++++++++++++++++ 4 files changed, 70 insertions(+), 3 deletions(-) diff --git a/packages/workbox-core/_private/cacheWrapper.mjs b/packages/workbox-core/_private/cacheWrapper.mjs index 8ac36ced1..584d0e7e5 100644 --- a/packages/workbox-core/_private/cacheWrapper.mjs +++ b/packages/workbox-core/_private/cacheWrapper.mjs @@ -133,7 +133,8 @@ const matchWrapper = async ({ logger.debug(`No cached response found in '${cacheName}'.`); } } - for (let plugin of plugins) { + + for (const plugin of plugins) { if (pluginEvents.CACHED_RESPONSE_WILL_BE_USED in plugin) { cachedResponse = await plugin[pluginEvents.CACHED_RESPONSE_WILL_BE_USED] .call(plugin, { @@ -154,6 +155,7 @@ const matchWrapper = async ({ } } } + return cachedResponse; }; diff --git a/packages/workbox-core/_private/fetchWrapper.mjs b/packages/workbox-core/_private/fetchWrapper.mjs index 15d106d7a..be213727f 100644 --- a/packages/workbox-core/_private/fetchWrapper.mjs +++ b/packages/workbox-core/_private/fetchWrapper.mjs @@ -102,12 +102,34 @@ const wrappedFetch = async ({ const pluginFilteredRequest = request.clone(); try { - const fetchResponse = await fetch(request, fetchOptions); + let fetchResponse = await fetch(request, fetchOptions); if (process.env.NODE_ENV !== 'production') { logger.debug(`Network request for `+ `'${getFriendlyURL(request.url)}' returned a response with ` + `status '${fetchResponse.status}'.`); } + + for (const plugin of plugins) { + if (pluginEvents.FETCH_DID_SUCCEED in plugin) { + fetchResponse = await plugin[pluginEvents.FETCH_DID_SUCCEED] + .call(plugin, { + event, + request: pluginFilteredRequest, + response: fetchResponse, + }); + + if (process.env.NODE_ENV !== 'production') { + if (fetchResponse) { + assert.isInstance(fetchResponse, Response, { + moduleName: 'Plugin', + funcName: pluginEvents.FETCH_DID_SUCCEED, + isReturnValueProblem: true, + }); + } + } + } + } + return fetchResponse; } catch (error) { if (process.env.NODE_ENV !== 'production') { @@ -115,7 +137,7 @@ const wrappedFetch = async ({ `'${getFriendlyURL(request.url)}' threw an error.`, error); } - for (let plugin of failedFetchPlugins) { + for (const plugin of failedFetchPlugins) { await plugin[pluginEvents.FETCH_DID_FAIL].call(plugin, { error, event, diff --git a/packages/workbox-core/models/pluginEvents.mjs b/packages/workbox-core/models/pluginEvents.mjs index cc7bf949a..c1f185870 100644 --- a/packages/workbox-core/models/pluginEvents.mjs +++ b/packages/workbox-core/models/pluginEvents.mjs @@ -13,5 +13,6 @@ export default { CACHE_WILL_UPDATE: 'cacheWillUpdate', CACHED_RESPONSE_WILL_BE_USED: 'cachedResponseWillBeUsed', FETCH_DID_FAIL: 'fetchDidFail', + FETCH_DID_SUCCEED: 'fetchDidSucceed', REQUEST_WILL_FETCH: 'requestWillFetch', }; diff --git a/test/workbox-core/node/_private/test-fetchWrapper.mjs b/test/workbox-core/node/_private/test-fetchWrapper.mjs index 9923e1ea3..aa74206bb 100644 --- a/test/workbox-core/node/_private/test-fetchWrapper.mjs +++ b/test/workbox-core/node/_private/test-fetchWrapper.mjs @@ -178,5 +178,47 @@ describe(`workbox-core fetchWrapper`, function() { const fetchRequest = global.fetch.args[0][0]; expect(fetchRequest.url).to.equal('/test/failingRequest/1'); }); + + it(`should call the fetchDidSucceed method in plugins`, async function() { + const originalRequest = new Request('/testing'); + + sandbox.stub(global, 'fetch').resolves(new Response('', { + headers: { + 'x-count': 1, + }, + })); + + const fetchDidSucceed = sandbox.stub().callsFake(({response}) => { + const count = response.headers.get('x-count'); + return new Response('', { + headers: { + 'x-count': count + 1, + }, + }); + }); + + const event = new FetchEvent('fetch', {request: originalRequest}); + + const finalResponse = await fetchWrapper.fetch({ + event, + request: originalRequest, + plugins: [ + // Two plugins, both with the same callback. + {fetchDidSucceed}, + {fetchDidSucceed}, + ], + }); + + expect(fetchDidSucceed.callCount).to.eql(2); + + for (const args of fetchDidSucceed.args) { + expect(args[0].request).to.be.instanceOf(Request); + expect(args[0].response).to.be.instanceOf(Response); + expect(args[0].event).to.be.instanceOf(FetchEvent); + } + + const finalCount = finalResponse.headers.get('x-count'); + expect(finalCount).to.eql(3); + }); }); });