2022-07-06 15:02:44 -07:00
|
|
|
import { Map as ImmutableMap } from 'immutable';
|
2022-06-20 06:46:43 -07:00
|
|
|
|
2022-07-06 15:02:44 -07:00
|
|
|
import { mockStore, rootState } from 'soapbox/jest/test-helpers';
|
2022-03-28 13:30:27 -07:00
|
|
|
import { InstanceRecord } from 'soapbox/normalizers';
|
|
|
|
|
|
|
|
import { uploadCompose } from '../compose';
|
|
|
|
|
2022-07-06 15:02:44 -07:00
|
|
|
import type { IntlShape } from 'react-intl';
|
|
|
|
|
2022-03-28 13:30:27 -07:00
|
|
|
describe('uploadCompose()', () => {
|
|
|
|
describe('with images', () => {
|
2022-07-06 15:02:44 -07:00
|
|
|
let files: FileList, store: ReturnType<typeof mockStore>;
|
2022-03-28 13:30:27 -07:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const instance = InstanceRecord({
|
2022-07-06 15:02:44 -07:00
|
|
|
configuration: ImmutableMap({
|
|
|
|
statuses: ImmutableMap({
|
2022-03-28 13:30:27 -07:00
|
|
|
max_media_attachments: 4,
|
2022-07-06 15:02:44 -07:00
|
|
|
}),
|
|
|
|
media_attachments: ImmutableMap({
|
2022-03-28 13:30:27 -07:00
|
|
|
image_size_limit: 10,
|
2022-07-06 15:02:44 -07:00
|
|
|
}),
|
2022-06-20 06:46:43 -07:00
|
|
|
}),
|
2022-03-28 13:30:27 -07:00
|
|
|
});
|
|
|
|
|
2022-07-06 15:02:44 -07:00
|
|
|
const state = rootState
|
2022-03-28 13:30:27 -07:00
|
|
|
.set('me', '1234')
|
|
|
|
.set('instance', instance);
|
|
|
|
|
|
|
|
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;
|
2022-03-28 13:30:27 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('creates an alert if exceeds max size', async() => {
|
2022-03-30 07:36:01 -07:00
|
|
|
const mockIntl = {
|
|
|
|
formatMessage: jest.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
|
|
|
|
2022-03-28 13:30:27 -07:00
|
|
|
const expectedActions = [
|
|
|
|
{ type: 'COMPOSE_UPLOAD_REQUEST', skipLoading: true },
|
|
|
|
{
|
|
|
|
type: 'ALERT_SHOW',
|
|
|
|
message: 'Image exceeds the current file size limit (10 Bytes)',
|
|
|
|
actionLabel: undefined,
|
|
|
|
actionLink: undefined,
|
|
|
|
severity: 'error',
|
|
|
|
},
|
|
|
|
{ type: 'COMPOSE_UPLOAD_FAIL', error: true, skipLoading: true },
|
|
|
|
];
|
|
|
|
|
2022-03-30 07:36:01 -07:00
|
|
|
await store.dispatch(uploadCompose(files, mockIntl));
|
2022-03-28 13:30:27 -07:00
|
|
|
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>;
|
2022-03-28 13:30:27 -07:00
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
const instance = InstanceRecord({
|
2022-07-06 15:02:44 -07:00
|
|
|
configuration: ImmutableMap({
|
|
|
|
statuses: ImmutableMap({
|
2022-03-28 13:30:27 -07:00
|
|
|
max_media_attachments: 4,
|
2022-07-06 15:02:44 -07:00
|
|
|
}),
|
|
|
|
media_attachments: ImmutableMap({
|
2022-03-28 13:30:27 -07:00
|
|
|
video_size_limit: 10,
|
2022-07-06 15:02:44 -07:00
|
|
|
}),
|
2022-06-20 06:46:43 -07:00
|
|
|
}),
|
2022-03-28 13:30:27 -07:00
|
|
|
});
|
|
|
|
|
2022-07-06 15:02:44 -07:00
|
|
|
const state = rootState
|
2022-03-28 13:30:27 -07:00
|
|
|
.set('me', '1234')
|
|
|
|
.set('instance', instance);
|
|
|
|
|
|
|
|
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;
|
2022-03-28 13:30:27 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
it('creates an alert if exceeds max size', async() => {
|
2022-03-30 07:36:01 -07:00
|
|
|
const mockIntl = {
|
|
|
|
formatMessage: jest.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
|
|
|
|
2022-03-28 13:30:27 -07:00
|
|
|
const expectedActions = [
|
|
|
|
{ type: 'COMPOSE_UPLOAD_REQUEST', skipLoading: true },
|
|
|
|
{
|
|
|
|
type: 'ALERT_SHOW',
|
|
|
|
message: 'Video exceeds the current file size limit (10 Bytes)',
|
|
|
|
actionLabel: undefined,
|
|
|
|
actionLink: undefined,
|
|
|
|
severity: 'error',
|
|
|
|
},
|
|
|
|
{ type: 'COMPOSE_UPLOAD_FAIL', error: true, skipLoading: true },
|
|
|
|
];
|
|
|
|
|
2022-03-30 07:36:01 -07:00
|
|
|
await store.dispatch(uploadCompose(files, mockIntl));
|
2022-03-28 13:30:27 -07:00
|
|
|
const actions = store.getActions();
|
|
|
|
|
|
|
|
expect(actions).toEqual(expectedActions);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|