pleroma/app/soapbox/reducers/__tests__/carousels.test.ts

51 lines
1.5 KiB
TypeScript
Raw Normal View History

2022-06-22 05:55:42 -07:00
import { AnyAction } from 'redux';
import {
CAROUSEL_AVATAR_REQUEST,
CAROUSEL_AVATAR_SUCCESS,
CAROUSEL_AVATAR_FAIL,
} from 'soapbox/actions/carousels';
import reducer from '../carousels';
describe('carousels reducer', () => {
it('should return the initial state', () => {
expect(reducer(undefined, {} as AnyAction)).toEqual({
avatars: [],
2022-06-23 09:01:32 -07:00
error: false,
2022-06-22 05:55:42 -07:00
isLoading: false,
});
});
describe('CAROUSEL_AVATAR_REQUEST', () => {
it('sets "isLoading" to "true"', () => {
2022-07-06 09:53:55 -07:00
const initialState = { isLoading: false, avatars: [], error: false };
2022-06-22 05:55:42 -07:00
const action = { type: CAROUSEL_AVATAR_REQUEST };
expect(reducer(initialState, action).isLoading).toEqual(true);
});
});
describe('CAROUSEL_AVATAR_SUCCESS', () => {
it('sets the next state', () => {
2022-06-23 09:01:32 -07:00
const initialState = { isLoading: true, avatars: [], error: false };
2022-06-22 05:55:42 -07:00
const action = { type: CAROUSEL_AVATAR_SUCCESS, payload: [45] };
const result = reducer(initialState, action);
expect(result.isLoading).toEqual(false);
expect(result.avatars).toEqual([45]);
2022-06-23 06:26:13 -07:00
expect(result.error).toEqual(false);
2022-06-22 05:55:42 -07:00
});
});
describe('CAROUSEL_AVATAR_FAIL', () => {
it('sets "isLoading" to "true"', () => {
2022-07-06 09:53:55 -07:00
const initialState = { isLoading: true, avatars: [], error: false };
2022-06-22 05:55:42 -07:00
const action = { type: CAROUSEL_AVATAR_FAIL };
2022-06-23 06:26:13 -07:00
const result = reducer(initialState, action);
expect(result.isLoading).toEqual(false);
expect(result.error).toEqual(true);
2022-06-22 05:55:42 -07:00
});
});
});