2023-11-20 11:00:51 +00:00
|
|
|
import {renderHook} from '@testing-library/react';
|
|
|
|
import React, {ReactNode} from 'react';
|
2023-12-14 16:01:28 +00:00
|
|
|
import {FrameworkProvider} from '../../../../src/providers/FrameworkProvider';
|
2023-11-20 11:00:51 +00:00
|
|
|
import {useFetchApi} from '../../../../src/utils/api/fetchApi';
|
|
|
|
import {withMockFetch} from '../../../utils/mockFetch';
|
|
|
|
|
|
|
|
const wrapper: React.FC<{ children: ReactNode }> = ({children}) => (
|
|
|
|
<FrameworkProvider
|
|
|
|
externalNavigate={() => {}}
|
|
|
|
ghostVersion='5.x'
|
|
|
|
sentryDSN=''
|
|
|
|
unsplashConfig={{
|
|
|
|
Authorization: '',
|
|
|
|
'Accept-Version': '',
|
|
|
|
'Content-Type': '',
|
|
|
|
'App-Pragma': '',
|
|
|
|
'X-Unsplash-Cache': true
|
|
|
|
}}
|
|
|
|
onDelete={() => {}}
|
|
|
|
onInvalidate={() => {}}
|
|
|
|
onUpdate={() => {}}
|
|
|
|
>
|
|
|
|
{children}
|
|
|
|
</FrameworkProvider>
|
|
|
|
);
|
|
|
|
|
|
|
|
describe('useFetchApi', function () {
|
|
|
|
it('makes an API request', async function () {
|
|
|
|
await withMockFetch({
|
|
|
|
json: {test: 1}
|
|
|
|
}, async (mock) => {
|
|
|
|
const {result} = renderHook(() => useFetchApi(), {wrapper});
|
|
|
|
|
|
|
|
const data = await result.current<{test: number}>('http://localhost:3000/ghost/api/admin/test/', {
|
|
|
|
method: 'POST',
|
|
|
|
body: 'test',
|
|
|
|
retry: false
|
|
|
|
});
|
|
|
|
|
|
|
|
expect(data).toEqual({test: 1});
|
|
|
|
|
|
|
|
expect(mock.calls.length).toBe(1);
|
|
|
|
expect(mock.calls[0]).toEqual(['http://localhost:3000/ghost/api/admin/test/', {
|
|
|
|
body: 'test',
|
|
|
|
credentials: 'include',
|
|
|
|
headers: {
|
|
|
|
'app-pragma': 'no-cache',
|
|
|
|
'x-ghost-version': '5.x',
|
|
|
|
'content-type': 'application/json'
|
|
|
|
},
|
|
|
|
method: 'POST',
|
|
|
|
mode: 'cors',
|
|
|
|
signal: expect.any(AbortSignal)
|
|
|
|
}]);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|