diff --git a/packages/core-data/src/queried-data/get-query-parts.js b/packages/core-data/src/queried-data/get-query-parts.js index b3744655728667..44b9b29f6eaa3b 100644 --- a/packages/core-data/src/queried-data/get-query-parts.js +++ b/packages/core-data/src/queried-data/get-query-parts.js @@ -8,6 +8,13 @@ import { addQueryArgs } from '@wordpress/url'; */ import { withWeakMapCache, getNormalizedCommaSeparable } from '../utils'; +function appendToStableKey( stableKey, key, value ) { + stableKey += + ( stableKey ? '&' : '' ) + + addQueryArgs( '', { [ key ]: value } ).slice( 1 ); + return stableKey; +} + /** * An object of properties describing a specific query. * @@ -60,6 +67,12 @@ export function getQueryParts( query ) { case 'per_page': parts.perPage = Number( value ); + // Add query param to stableKey to ensure it's included in cache key. + parts.stableKey = appendToStableKey( + parts.stableKey, + key, + parts.perPage + ); break; case 'context': @@ -97,9 +110,11 @@ export function getQueryParts( query ) { // should accept a key value pair, which may optimize its // implementation for our use here, vs. iterating an object // with only a single key. - parts.stableKey += - ( parts.stableKey ? '&' : '' ) + - addQueryArgs( '', { [ key ]: value } ).slice( 1 ); + parts.stableKey = appendToStableKey( + parts.stableKey, + key, + value + ); } } diff --git a/packages/core-data/src/queried-data/test/get-query-parts.js b/packages/core-data/src/queried-data/test/get-query-parts.js index f355be21a439b9..22307cbd2859af 100644 --- a/packages/core-data/src/queried-data/test/get-query-parts.js +++ b/packages/core-data/src/queried-data/test/get-query-parts.js @@ -4,14 +4,14 @@ import { getQueryParts } from '../get-query-parts'; describe( 'getQueryParts', () => { - it( 'parses out pagination data', () => { + it( 'parses out pagination data and adds to returned object', () => { const parts = getQueryParts( { page: 2, per_page: 2 } ); expect( parts ).toEqual( { context: 'default', page: 2, perPage: 2, - stableKey: '', + stableKey: 'per_page=2', fields: null, include: null, } ); @@ -71,7 +71,7 @@ describe( 'getQueryParts', () => { context: 'default', page: 1, perPage: 10, - stableKey: 'b=2', + stableKey: 'b=2&per_page=10', fields: null, include: null, } ); @@ -84,7 +84,7 @@ describe( 'getQueryParts', () => { context: 'default', page: 1, perPage: -1, - stableKey: 'b=2', + stableKey: 'b=2&per_page=-1', fields: null, include: null, } ); diff --git a/packages/core-data/src/queried-data/test/reducer.js b/packages/core-data/src/queried-data/test/reducer.js index d996f5b07ea22b..fd2c6cc24a3ff2 100644 --- a/packages/core-data/src/queried-data/test/reducer.js +++ b/packages/core-data/src/queried-data/test/reducer.js @@ -170,7 +170,7 @@ describe( 'reducer', () => { default: { 1: true }, }, queries: { - default: { 's=a': { itemIds: [ 1 ] } }, + default: { 'per_page=3&s=a': { itemIds: [ 1 ] } }, }, } ); } );