Files
react-native/Libraries/Modal/__tests__/Modal-test.js
T
Rujin Cao b2ac528156 @emails -> @oncall (remaining ones)
Differential Revision: D39536169

fbshipit-source-id: 6c8d6787328eefecd23f3498b14a6d9ff750a670
2022-09-15 15:54:10 -07:00

70 lines
1.6 KiB
JavaScript

/**
* Copyright (c) Meta Platforms, Inc. and affiliates.
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
*
* @flow strict-local
* @format
* @oncall react_native
*/
'use strict';
const React = require('react');
const View = require('../../Components/View/View');
const Modal = require('../Modal');
const render = require('../../../jest/renderer');
describe('<Modal />', () => {
it('should render as <Modal> when mocked', () => {
const instance = render.create(
<Modal>
<View />
</Modal>,
);
expect(instance).toMatchSnapshot();
});
it('should not render its children when mocked with visible=false', () => {
const instance = render.create(
<Modal visible={false}>
<View testID="child" />
</Modal>,
);
expect(instance.root.findAllByProps({testID: 'child'})).toHaveLength(0);
});
it('should shallow render as <Modal> when mocked', () => {
const output = render.shallow(
<Modal>
<View />
</Modal>,
);
expect(output).toMatchSnapshot();
});
it('should shallow render as <Modal> when not mocked', () => {
jest.dontMock('../Modal');
const output = render.shallow(
<Modal>
<View />
</Modal>,
);
expect(output).toMatchSnapshot();
});
it('should render as <RCTModalHostView> when not mocked', () => {
jest.dontMock('../Modal');
const instance = render.create(
<Modal>
<View />
</Modal>,
);
expect(instance).toMatchSnapshot();
});
});