mirror of
https://github.com/philomena-dev/philomena.git
synced 2024-12-11 03:28:01 +01:00
84 lines
2.3 KiB
TypeScript
84 lines
2.3 KiB
TypeScript
import { fetchHtml, fetchJson, handleError } from '../requests';
|
|
import fetchMock from 'jest-fetch-mock';
|
|
|
|
describe('Request utils', () => {
|
|
const mockEndpoint = '/endpoint';
|
|
|
|
beforeAll(() => {
|
|
fetchMock.enableMocks();
|
|
});
|
|
|
|
afterAll(() => {
|
|
fetchMock.disableMocks();
|
|
});
|
|
|
|
beforeEach(() => {
|
|
window.booru.csrfToken = Math.random().toString();
|
|
fetchMock.resetMocks();
|
|
});
|
|
|
|
describe('fetchJson', () => {
|
|
it('should call native fetch with the correct parameters (without body)', () => {
|
|
const mockVerb = 'GET';
|
|
|
|
fetchJson(mockVerb, mockEndpoint);
|
|
|
|
expect(fetch).toHaveBeenNthCalledWith(1, mockEndpoint, {
|
|
method: mockVerb,
|
|
credentials: 'same-origin',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
'x-csrf-token': window.booru.csrfToken,
|
|
'x-requested-with': 'xmlhttprequest'
|
|
},
|
|
});
|
|
});
|
|
|
|
it('should call native fetch with the correct parameters (with body)', () => {
|
|
const mockVerb = 'POST';
|
|
const mockBody = { mockField: Math.random() };
|
|
|
|
fetchJson(mockVerb, mockEndpoint, mockBody);
|
|
|
|
expect(fetch).toHaveBeenNthCalledWith(1, mockEndpoint, {
|
|
method: mockVerb,
|
|
credentials: 'same-origin',
|
|
headers: {
|
|
'Content-Type': 'application/json',
|
|
'x-csrf-token': window.booru.csrfToken,
|
|
'x-requested-with': 'xmlhttprequest'
|
|
},
|
|
body: JSON.stringify({
|
|
...mockBody,
|
|
_method: mockVerb
|
|
})
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('fetchHtml', () => {
|
|
it('should call native fetch with the correct parameters', () => {
|
|
fetchHtml(mockEndpoint);
|
|
|
|
expect(fetch).toHaveBeenNthCalledWith(1, mockEndpoint, {
|
|
credentials: 'same-origin',
|
|
headers: {
|
|
'x-csrf-token': window.booru.csrfToken,
|
|
'x-requested-with': 'xmlhttprequest'
|
|
},
|
|
});
|
|
});
|
|
});
|
|
|
|
describe('handleError', () => {
|
|
it('should throw if ok property is false', () => {
|
|
const mockResponse = { ok: false } as unknown as Response;
|
|
expect(() => handleError(mockResponse)).toThrow('Received error from server');
|
|
});
|
|
|
|
it('should return response if ok property is true', () => {
|
|
const mockResponse = { ok: true } as unknown as Response;
|
|
expect(handleError(mockResponse)).toEqual(mockResponse);
|
|
});
|
|
});
|
|
});
|