bigbuffet-rw/app/soapbox/actions/__tests__/compose.test.ts

128 lines
3.8 KiB
TypeScript
Raw Normal View History

2022-07-26 10:53:08 -07:00
import { Map as ImmutableMap, OrderedSet as ImmutableOrderedSet } from 'immutable';
2022-07-06 15:02:44 -07:00
import { mockStore, rootState } from 'soapbox/jest/test-helpers';
import { InstanceRecord } from 'soapbox/normalizers';
import { ReducerCompose } from 'soapbox/reducers/compose';
2022-07-26 10:53:08 -07:00
import { uploadCompose, submitCompose } from '../compose';
import { STATUS_CREATE_REQUEST } from '../statuses';
2022-07-06 15:02:44 -07:00
import type { IntlShape } from 'react-intl';
describe('uploadCompose()', () => {
describe('with images', () => {
2022-07-06 15:02:44 -07:00
let files: FileList, store: ReturnType<typeof mockStore>;
beforeEach(() => {
const instance = InstanceRecord({
2022-07-06 15:02:44 -07:00
configuration: ImmutableMap({
statuses: ImmutableMap({
max_media_attachments: 4,
2022-07-06 15:02:44 -07:00
}),
media_attachments: ImmutableMap({
image_size_limit: 10,
2022-07-06 15:02:44 -07:00
}),
}),
});
2022-07-06 15:02:44 -07:00
const state = rootState
.set('me', '1234')
.set('instance', instance)
.setIn(['compose', 'home'], ReducerCompose());
store = mockStore(state);
files = [{
uri: 'image.png',
name: 'Image',
size: 15,
type: 'image/png',
2022-07-06 15:02:44 -07:00
}] as unknown as FileList;
});
it('creates an alert if exceeds max size', async() => {
2022-03-30 07:36:01 -07:00
const mockIntl = {
2023-09-16 13:16:59 -07:00
formatMessage: vi.fn().mockReturnValue('Image exceeds the current file size limit (10 Bytes)'),
2022-07-06 15:02:44 -07:00
} as unknown as IntlShape;
2022-03-30 07:36:01 -07:00
const expectedActions = [
{ type: 'COMPOSE_UPLOAD_REQUEST', id: 'home', skipLoading: true },
{ type: 'COMPOSE_UPLOAD_FAIL', id: 'home', error: true, skipLoading: true },
];
await store.dispatch(uploadCompose('home', files, mockIntl));
const actions = store.getActions();
expect(actions).toEqual(expectedActions);
});
});
describe('with videos', () => {
2022-07-06 15:02:44 -07:00
let files: FileList, store: ReturnType<typeof mockStore>;
beforeEach(() => {
const instance = InstanceRecord({
2022-07-06 15:02:44 -07:00
configuration: ImmutableMap({
statuses: ImmutableMap({
max_media_attachments: 4,
2022-07-06 15:02:44 -07:00
}),
media_attachments: ImmutableMap({
video_size_limit: 10,
2022-07-06 15:02:44 -07:00
}),
}),
});
2022-07-06 15:02:44 -07:00
const state = rootState
.set('me', '1234')
.set('instance', instance)
.setIn(['compose', 'home'], ReducerCompose());
store = mockStore(state);
files = [{
uri: 'video.mp4',
name: 'Video',
size: 15,
type: 'video/mp4',
2022-07-06 15:02:44 -07:00
}] as unknown as FileList;
});
it('creates an alert if exceeds max size', async() => {
2022-03-30 07:36:01 -07:00
const mockIntl = {
2023-09-16 13:16:59 -07:00
formatMessage: vi.fn().mockReturnValue('Video exceeds the current file size limit (10 Bytes)'),
2022-07-06 15:02:44 -07:00
} as unknown as IntlShape;
2022-03-30 07:36:01 -07:00
const expectedActions = [
{ type: 'COMPOSE_UPLOAD_REQUEST', id: 'home', skipLoading: true },
{ type: 'COMPOSE_UPLOAD_FAIL', id: 'home', error: true, skipLoading: true },
];
await store.dispatch(uploadCompose('home', files, mockIntl));
const actions = store.getActions();
expect(actions).toEqual(expectedActions);
});
});
});
2022-07-26 10:53:08 -07:00
describe('submitCompose()', () => {
it('inserts mentions from text', async() => {
const state = rootState
.set('me', '123')
.setIn(['compose', 'home'], ReducerCompose({ text: '@alex hello @mkljczk@pl.fediverse.pl @gg@汉语/漢語.com alex@alexgleason.me' }));
2022-07-26 10:53:08 -07:00
const store = mockStore(state);
await store.dispatch(submitCompose('home'));
2022-07-26 10:53:08 -07:00
const actions = store.getActions();
const statusCreateRequest = actions.find(action => action.type === STATUS_CREATE_REQUEST);
const to = statusCreateRequest!.params.to as ImmutableOrderedSet<string>;
const expected = [
'alex',
'mkljczk@pl.fediverse.pl',
'gg@汉语/漢語.com',
];
expect(to.toJS()).toEqual(expected);
});
});