Files
mattermost-mobile/app/screens/image_preview/image_preview.test.js
Mattermost Build dfc50b7dff Automated cherry pick of #3618 (#3627)
* Use bottom sheet over modal

* check-style fixes
2019-11-28 08:12:45 -03:00

226 lines
6.6 KiB
JavaScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react';
import {shallow} from 'enzyme';
import {
TouchableOpacity,
} from 'react-native';
import RNFetchBlob from 'rn-fetch-blob';
import Preferences from 'mattermost-redux/constants/preferences';
import * as NavigationActions from 'app/actions/navigation';
import BottomSheet from 'app/utils/bottom_sheet';
import ImagePreview from './image_preview';
jest.useFakeTimers();
jest.mock('react-intl');
jest.mock('react-native-doc-viewer', () => {
return {
OpenFile: jest.fn(),
};
});
jest.mock('react-native-permissions', () => {
return {
check: jest.fn(),
};
});
describe('ImagePreview', () => {
const baseProps = {
canDownloadFiles: true,
deviceHeight: 400,
deviceWidth: 300,
files: [
{caption: 'Caption 1', source: 'source', data: 'data'},
{caption: 'Caption 2', source: 'source', data: 'data'},
],
getItemMeasures: jest.fn(),
index: 0,
origin: {},
target: {},
theme: Preferences.THEMES.default,
componentId: 'component-id',
};
test('should match snapshot', () => {
const wrapper = shallow(
<ImagePreview {...baseProps}/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
expect(wrapper.getElement()).toMatchSnapshot();
expect(wrapper.find(TouchableOpacity).first().exists()).toEqual(true);
});
test('should match snapshot, renderDownloadButton', () => {
const wrapper = shallow(
<ImagePreview {...baseProps}/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
expect(wrapper.instance().renderDownloadButton()).toMatchSnapshot();
});
test('should match snapshot and not renderDownloadButton for local files', () => {
const props = {
...baseProps,
files: [{caption: 'Caption 1', source: 'source', data: {localPath: 'path'}}],
};
const wrapper = shallow(
<ImagePreview {...props}/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
expect(wrapper.instance().renderDownloadButton()).toMatchSnapshot();
expect(wrapper.instance().renderDownloadButton()).toBeNull();
});
test('should match state on handleChangeImage', () => {
const wrapper = shallow(
<ImagePreview {...baseProps}/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
wrapper.setState({index: 0});
wrapper.instance().handleChangeImage(1);
expect(wrapper.state('index')).toEqual(1);
});
test('should match call getItemMeasures & mergeNavigationOptions on close', () => {
const mergeNavigationOptions = jest.spyOn(NavigationActions, 'mergeNavigationOptions');
const getItemMeasures = jest.fn();
const wrapper = shallow(
<ImagePreview
{...baseProps}
getItemMeasures={getItemMeasures}
/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
wrapper.instance().close();
expect(mergeNavigationOptions).toHaveBeenCalledTimes(2);
expect(mergeNavigationOptions).toHaveBeenCalledWith(
baseProps.componentId,
{
layout: {
backgroundColor: 'transparent',
},
},
);
});
test('should show bottom sheet when showDownloadOptionsIOS is called for existing video', async () => {
BottomSheet.showBottomSheetWithOptions = jest.fn();
RNFetchBlob.fs.exists = jest.fn().mockReturnValue(true);
const formatMessage = jest.fn(({defaultMessage}) => {
return defaultMessage;
});
const index = 0;
const files = [{
caption: 'caption',
data: {
mime_type: 'video/mp4',
},
}];
const props = {
...baseProps,
index,
files,
};
const wrapper = shallow(
<ImagePreview
{...props}
/>,
{context: {intl: {formatMessage}}},
);
const instance = wrapper.instance();
await instance.showDownloadOptionsIOS();
const expectedOptions = {
options: ['Save Video', 'Cancel'],
cancelButtonIndex: 1,
anchor: null,
title: files[index].caption,
};
expect(BottomSheet.showBottomSheetWithOptions).
toHaveBeenCalledWith(expectedOptions, expect.any(Function));
});
test('should not show bottom sheet when showDownloadOptionsIOS is called for non-existing video', async () => {
BottomSheet.showBottomSheetWithOptions = jest.fn();
RNFetchBlob.fs.exists = jest.fn().mockReturnValue(false);
const index = 0;
const files = [{
caption: 'caption',
data: {
mime_type: 'video/mp4',
},
}];
const props = {
...baseProps,
index,
files,
};
const wrapper = shallow(
<ImagePreview
{...props}
/>,
{context: {intl: {formatMessage: jest.fn()}}},
);
const instance = wrapper.instance();
await instance.showDownloadOptionsIOS();
expect(BottomSheet.showBottomSheetWithOptions).not.toHaveBeenCalled();
});
test('should show bottom sheet when showDownloadOptionsIOS is called for image', async () => {
BottomSheet.showBottomSheetWithOptions = jest.fn();
RNFetchBlob.fs.exists = jest.fn().mockReturnValue(true);
const formatMessage = jest.fn(({defaultMessage}) => {
return defaultMessage;
});
const index = 0;
const files = [{
caption: 'caption',
data: {
mime_type: 'image/jpeg',
},
}];
const props = {
...baseProps,
index,
files,
};
const wrapper = shallow(
<ImagePreview
{...props}
/>,
{context: {intl: {formatMessage}}},
);
const instance = wrapper.instance();
await instance.showDownloadOptionsIOS();
const expectedOptions = {
options: ['Save Image', 'Cancel'],
cancelButtonIndex: 1,
anchor: null,
title: files[index].caption,
};
expect(BottomSheet.showBottomSheetWithOptions).
toHaveBeenCalledWith(expectedOptions, expect.any(Function));
});
});