From 2a171a9b63e9c3bec1fb8991b533c61b824dd736 Mon Sep 17 00:00:00 2001 From: Haroen Viaene Date: Tue, 10 Sep 2024 09:30:37 +0200 Subject: [PATCH] fix(client): ensure client.search is bound (#6352) * fix(client): ensure client.search is bound fixes #6350 fixes algolia/algoliasearch-client-javascript#1549 possibly also solves #6348, to investigate afterwards * fix lint --- .../__tests__/hydrateSearchClient-test.ts | 54 +++++++++++++++++++ .../src/lib/utils/hydrateSearchClient.ts | 2 +- 2 files changed, 55 insertions(+), 1 deletion(-) diff --git a/packages/instantsearch.js/src/lib/utils/__tests__/hydrateSearchClient-test.ts b/packages/instantsearch.js/src/lib/utils/__tests__/hydrateSearchClient-test.ts index e470c76a9c..66fc52c0a2 100644 --- a/packages/instantsearch.js/src/lib/utils/__tests__/hydrateSearchClient-test.ts +++ b/packages/instantsearch.js/src/lib/utils/__tests__/hydrateSearchClient-test.ts @@ -1,3 +1,7 @@ +import algoliasearchV3 from 'algoliasearch-v3'; +import algoliasearchV4 from 'algoliasearch-v4'; +import { liteClient as algoliasearchV5 } from 'algoliasearch-v5/lite'; + import { hydrateSearchClient } from '../hydrateSearchClient'; import type { SearchClient, InitialResults } from '../../../types'; @@ -44,6 +48,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: setCache } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, initialResults); @@ -64,6 +69,7 @@ describe('hydrateSearchClient', () => { it('should populate the cache for < v4 if there is no transporter object', () => { client = { addAlgoliaAgent: jest.fn(), + search: jest.fn(), _useCache: true, } as unknown as SearchClient; @@ -77,6 +83,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: setCache } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, { @@ -110,6 +117,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: setCache } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, { @@ -176,6 +184,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: setCache } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, { @@ -204,6 +213,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: jest.fn() } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, { @@ -221,6 +231,7 @@ describe('hydrateSearchClient', () => { client = { transporter: { responsesCache: { set: setCache } }, addAlgoliaAgent: jest.fn(), + search: jest.fn(), } as unknown as SearchClient; hydrateSearchClient(client, { @@ -235,4 +246,47 @@ describe('hydrateSearchClient', () => { { results: [] } ); }); + + it('should not throw if search requires to be bound (v5)', async () => { + const send = jest.fn().mockResolvedValue({ status: 200, content: '{}' }); + const searchClient: any = algoliasearchV5('appId', 'apiKey', { + requester: { + send, + }, + }); + + hydrateSearchClient(searchClient, initialResults); + + await searchClient.search([{ indexName: 'another', params: {} }]); + + expect(send).toHaveBeenCalled(); + }); + + it('should not throw if search requires to be bound (v4)', async () => { + const send = jest.fn().mockResolvedValue({ status: 200, content: '{}' }); + const searchClient: any = algoliasearchV4('appId', 'apiKey', { + requester: { + send, + }, + }); + + hydrateSearchClient(searchClient, initialResults); + + await searchClient.search([{ indexName: 'another', params: {} }]); + + expect(send).toHaveBeenCalled(); + }); + + it('should not throw if search requires to be bound (v3)', async () => { + const searchClient: any = algoliasearchV3('appId', 'apiKey'); + searchClient._request = jest + .fn() + .mockResolvedValue({ body: { status: 200 } }); + + hydrateSearchClient(searchClient, initialResults); + + await searchClient.search([{ indexName: 'another', params: {} }]); + + expect(searchClient._request).toHaveBeenCalled(); + }); }); diff --git a/packages/instantsearch.js/src/lib/utils/hydrateSearchClient.ts b/packages/instantsearch.js/src/lib/utils/hydrateSearchClient.ts index 4165fe411e..b08e1e4460 100644 --- a/packages/instantsearch.js/src/lib/utils/hydrateSearchClient.ts +++ b/packages/instantsearch.js/src/lib/utils/hydrateSearchClient.ts @@ -85,7 +85,7 @@ export function hydrateSearchClient( if ('transporter' in client && !client._cacheHydrated) { client._cacheHydrated = true; - const baseMethod = client.search as unknown as ( + const baseMethod = client.search.bind(client) as unknown as ( query: any, ...args: any[] ) => any;