From b3f02d82d17c21d603fc6d98266e80b6b41a8115 Mon Sep 17 00:00:00 2001 From: Diana Olarte Date: Tue, 29 Oct 2024 12:16:51 +1100 Subject: [PATCH] fix: logError and test implementation --- src/hooks/api.js | 3 ++- src/hooks/api.test.js | 20 ++++++++++++++------ 2 files changed, 16 insertions(+), 7 deletions(-) diff --git a/src/hooks/api.js b/src/hooks/api.js index 70a44809..24a844f8 100644 --- a/src/hooks/api.js +++ b/src/hooks/api.js @@ -1,5 +1,6 @@ import React from 'react'; +import { logError } from '@edx/frontend-platform/logging'; import { AppContext } from '@edx/frontend-platform/react'; import { RequestKeys } from 'data/constants/requests'; @@ -40,7 +41,7 @@ export const useProgramsConfig = () => { const { data } = await api.getProgramsConfig(); setConfig(data); } catch (error) { - console.error('Error accessing programs configuration', error); + logError(`Error accessing programs configuration ${error}`); } }; diff --git a/src/hooks/api.test.js b/src/hooks/api.test.js index 33c781ed..ab18a6df 100644 --- a/src/hooks/api.test.js +++ b/src/hooks/api.test.js @@ -1,4 +1,5 @@ import React from 'react'; +import { logError } from '@edx/frontend-platform/logging'; import { AppContext } from '@edx/frontend-platform/react'; import { keyStore } from 'utils'; import { RequestKeys } from 'data/constants/requests'; @@ -10,6 +11,10 @@ import * as apiHooks from './api'; const reduxKeys = keyStore(reduxHooks); +jest.mock('@edx/frontend-platform/logging', () => ({ + logError: jest.fn(), +})); + jest.mock('data/services/lms/utils', () => ({ post: jest.fn((...args) => ({ post: args })), })); @@ -114,9 +119,13 @@ describe('api hooks', () => { }); describe('useProgramsConfig', () => { - const mockState = {}; + let mockState; const setState = jest.fn((newState) => { Object.assign(mockState, newState); }); - React.useState.mockReturnValue([mockState, setState]); + beforeEach(() => { + mockState = {}; + React.useState.mockReturnValue([mockState, setState]); + }); + it('should return the programs configuration when the API call is successful', async () => { api.getProgramsConfig.mockResolvedValue({ data: { enabled: true } }); const config = apiHooks.useProgramsConfig(); @@ -126,15 +135,14 @@ describe('api hooks', () => { expect(config).toEqual({ enabled: true }); }); - it.only('should return an empty object if the api call fails', async () => { + it('should return an empty object if the api call fails', async () => { + mockState = {}; api.getProgramsConfig.mockRejectedValue(new Error('error test')); - const consoleSpy = jest.spyOn(global.console, 'error').mockImplementation(() => { }); const config = apiHooks.useProgramsConfig(); const [cb] = React.useEffect.mock.calls[0]; await cb(); - expect(config).toEqual({}); - expect(consoleSpy).toHaveBeenCalled(); + expect(logError).toHaveBeenCalled(); }); });