forked from Ivasoft/mattermost-mobile
* Upgrade to RN 0.63 * Bump to RN 0.63.1 * Fix RN patch * Use JSC Intl version * Update android/app/build.gradle Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com> * Fix Android external storage permission * Fix emoji imageUrl when no server url is present * Patch react-native-image-picker * Allow to post attachment only messages Co-authored-by: Miguel Alatzar <migbot@users.noreply.github.com>
306 lines
12 KiB
JavaScript
306 lines
12 KiB
JavaScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
import React from 'react';
|
|
import SafeArea from 'react-native-safe-area';
|
|
import {shallow} from 'enzyme';
|
|
|
|
import Preferences from '@mm-redux/constants/preferences';
|
|
|
|
import {DeviceTypes, ViewTypes} from 'app/constants';
|
|
import mattermostManaged from 'app/mattermost_managed';
|
|
import EphemeralStore from 'app/store/ephemeral_store';
|
|
|
|
import SafeAreaIos from './safe_area_view.ios';
|
|
|
|
const {PORTRAIT, LANDSCAPE} = ViewTypes;
|
|
|
|
describe('SafeAreaIos', () => {
|
|
const baseProps = {
|
|
children: [],
|
|
keyboardOffset: 100,
|
|
useLandscapeMargin: false,
|
|
theme: Preferences.THEMES.default,
|
|
};
|
|
|
|
const TEST_INSETS_1 = {
|
|
safeAreaInsets: {
|
|
top: 123,
|
|
left: 123,
|
|
bottom: 123,
|
|
right: 123,
|
|
},
|
|
};
|
|
|
|
const TEST_INSETS_2 = {
|
|
safeAreaInsets: {
|
|
top: 456,
|
|
left: 456,
|
|
bottom: 456,
|
|
right: 456,
|
|
},
|
|
};
|
|
|
|
const PORTRAIT_INSETS = {
|
|
safeAreaInsets: {
|
|
top: 111,
|
|
left: 111,
|
|
bottom: 111,
|
|
right: 111,
|
|
},
|
|
};
|
|
|
|
const LANDSCAPE_INSETS = {
|
|
safeAreaInsets: {
|
|
top: 222,
|
|
left: 222,
|
|
bottom: 222,
|
|
right: 222,
|
|
},
|
|
};
|
|
|
|
const IGNORED_INSETS = {
|
|
safeAreaInsets: {
|
|
top: 333,
|
|
left: 333,
|
|
bottom: 333,
|
|
right: 333,
|
|
},
|
|
};
|
|
|
|
SafeArea.getSafeAreaInsetsForRootView = jest.fn().mockImplementation(() => {
|
|
return Promise.resolve(TEST_INSETS_1);
|
|
});
|
|
|
|
beforeEach(() => {
|
|
EphemeralStore.safeAreaInsets = {
|
|
[PORTRAIT]: null,
|
|
[LANDSCAPE]: null,
|
|
};
|
|
});
|
|
|
|
test('should match snapshot', () => {
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.getElement()).toMatchSnapshot();
|
|
});
|
|
|
|
test('should get safe area insets on mount if DeviceTypes.IS_IPHONE_WITH_INSETS is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = true;
|
|
mattermostManaged.hasSafeAreaInsets = false;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(SafeArea.getSafeAreaInsetsForRootView).toHaveBeenCalled();
|
|
await SafeArea.getSafeAreaInsetsForRootView();
|
|
expect(wrapper.state().safeAreaInsets).toEqual(TEST_INSETS_1.safeAreaInsets);
|
|
});
|
|
|
|
test('should get safe area insets on mount if mattermostManaged.hasSafeAreaInsets is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = false;
|
|
mattermostManaged.hasSafeAreaInsets = true;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(SafeArea.getSafeAreaInsetsForRootView).toHaveBeenCalled();
|
|
await SafeArea.getSafeAreaInsetsForRootView();
|
|
expect(wrapper.state().safeAreaInsets).toEqual(TEST_INSETS_1.safeAreaInsets);
|
|
});
|
|
|
|
test('should not get safe area insets on mount if neither DeviceTypes.IS_IPHONE_WITH_INSET nor mattermostManaged.hasSafeAreaInsets is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = false;
|
|
mattermostManaged.hasSafeAreaInsets = false;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(SafeArea.getSafeAreaInsetsForRootView).not.toHaveBeenCalled();
|
|
await SafeArea.getSafeAreaInsetsForRootView();
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_1.safeAreaInsets);
|
|
});
|
|
|
|
test('should set safe area insets on change if mounted and DeviceTypes.IS_IPHONE_WITH_INSETS is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = true;
|
|
mattermostManaged.hasSafeAreaInsets = false;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
|
|
const instance = wrapper.instance();
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_2);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
});
|
|
|
|
test('should set safe area insets on change if mounted and mattermostManaged.hasSafeAreaInsets is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = false;
|
|
mattermostManaged.hasSafeAreaInsets = true;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
|
|
const instance = wrapper.instance();
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_2);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
});
|
|
|
|
test('should not set safe area insets on change if mounted and neither DeviceTypes.IS_IPHONE_WITH_INSETS nor mattermostManaged.hasSafeAreaInsets is true', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = false;
|
|
mattermostManaged.hasSafeAreaInsets = false;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
|
|
const instance = wrapper.instance();
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_2);
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
});
|
|
|
|
test('should set safe area insets on change not mounted', async () => {
|
|
DeviceTypes.IS_IPHONE_WITH_INSETS = true;
|
|
mattermostManaged.hasSafeAreaInsets = true;
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
|
|
const instance = wrapper.instance();
|
|
instance.mounted = false;
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_2);
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(TEST_INSETS_2.safeAreaInsets);
|
|
});
|
|
|
|
test('should set portrait safe area insets', async () => {
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
|
|
const orientation = PORTRAIT;
|
|
const instance = wrapper.instance();
|
|
instance.setSafeAreaInsets(PORTRAIT_INSETS.safeAreaInsets, orientation);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
});
|
|
|
|
test('should set portrait safe area insets from EphemeralStore', async () => {
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
EphemeralStore.safeAreaInsets[PORTRAIT] = PORTRAIT_INSETS.safeAreaInsets;
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
|
|
const orientation = PORTRAIT;
|
|
const instance = wrapper.instance();
|
|
instance.setSafeAreaInsets(IGNORED_INSETS.safeAreaInsets, orientation);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(PORTRAIT_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
});
|
|
|
|
test('should set landscape safe area insets', () => {
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
|
|
const orientation = LANDSCAPE;
|
|
const instance = wrapper.instance();
|
|
instance.setSafeAreaInsets(LANDSCAPE_INSETS.safeAreaInsets, orientation);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
});
|
|
|
|
test('should set landscape safe area insets from EphemeralStore', async () => {
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
|
|
EphemeralStore.safeAreaInsets[LANDSCAPE] = LANDSCAPE_INSETS.safeAreaInsets;
|
|
expect(wrapper.state().safeAreaInsets).not.toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
|
|
const orientation = LANDSCAPE;
|
|
const instance = wrapper.instance();
|
|
instance.setSafeAreaInsets(IGNORED_INSETS.safeAreaInsets, orientation);
|
|
expect(wrapper.state().safeAreaInsets).toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(LANDSCAPE_INSETS.safeAreaInsets);
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
});
|
|
|
|
test('should add safeAreaInsetsForRootViewDidChange listener when EphemeralStore values are not set', async () => {
|
|
const addEventListener = jest.spyOn(SafeArea, 'addEventListener');
|
|
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
let wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
let instance = wrapper.instance();
|
|
expect(addEventListener).toHaveBeenCalledWith('safeAreaInsetsForRootViewDidChange', instance.onSafeAreaInsetsForRootViewChange);
|
|
addEventListener.mockClear();
|
|
|
|
EphemeralStore.safeAreaInsets[PORTRAIT] = TEST_INSETS_1.safeAreaInsets;
|
|
wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
instance = wrapper.instance();
|
|
expect(addEventListener).toHaveBeenCalledWith('safeAreaInsetsForRootViewDidChange', instance.onSafeAreaInsetsForRootViewChange);
|
|
addEventListener.mockClear();
|
|
|
|
EphemeralStore.safeAreaInsets[PORTRAIT] = TEST_INSETS_1.safeAreaInsets;
|
|
EphemeralStore.safeAreaInsets[LANDSCAPE] = TEST_INSETS_1.safeAreaInsets;
|
|
wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
instance = wrapper.instance();
|
|
expect(addEventListener).not.toHaveBeenCalled();
|
|
});
|
|
|
|
test('should remove safeAreaInsetsForRootViewDidChange listener when EphemeralStore values are set', async () => {
|
|
const removeEventListener = jest.spyOn(SafeArea, 'removeEventListener');
|
|
|
|
const wrapper = shallow(
|
|
<SafeAreaIos {...baseProps}/>,
|
|
);
|
|
const instance = wrapper.instance();
|
|
expect(EphemeralStore.safeAreaInsets[PORTRAIT]).toEqual(null);
|
|
expect(EphemeralStore.safeAreaInsets[LANDSCAPE]).toEqual(null);
|
|
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_1);
|
|
expect(removeEventListener).not.toHaveBeenCalled();
|
|
|
|
EphemeralStore.safeAreaInsets[PORTRAIT] = TEST_INSETS_1.safeAreaInsets;
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_1);
|
|
expect(removeEventListener).not.toHaveBeenCalled();
|
|
|
|
EphemeralStore.safeAreaInsets[LANDSCAPE] = TEST_INSETS_1.safeAreaInsets;
|
|
instance.onSafeAreaInsetsForRootViewChange(TEST_INSETS_1);
|
|
expect(removeEventListener).toHaveBeenCalledWith('safeAreaInsetsForRootViewDidChange', instance.onSafeAreaInsetsForRootViewChange);
|
|
});
|
|
});
|