123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- const h = require('react').createElement
- const { mount, configure } = require('enzyme')
- const ReactAdapter = require('enzyme-adapter-react-16')
- const Uppy = require('@uppy/core')
- jest.mock('@uppy/dashboard', () => require('./__mocks__/DashboardPlugin'))
- const DashboardModal = require('./DashboardModal')
- beforeAll(() => {
- configure({ adapter: new ReactAdapter() })
- })
- beforeEach(() => {
- Object.assign(require('@uppy/dashboard').prototype, {
- openModal: jest.fn(),
- closeModal: jest.fn()
- })
- })
- describe('react <DashboardModal />', () => {
- it('can be mounted and unmounted', () => {
- const oninstall = jest.fn()
- const onuninstall = jest.fn()
- const uppy = Uppy()
- const dash = mount((
- <DashboardModal
- uppy={uppy}
- onInstall={oninstall}
- onUninstall={onuninstall}
- />
- ))
- expect(oninstall).toHaveBeenCalled()
- expect(onuninstall).not.toHaveBeenCalled()
- dash.unmount()
- expect(oninstall).toHaveBeenCalled()
- expect(onuninstall).toHaveBeenCalled()
- })
- it('opens the modal using the `open={true}` prop', () => {
- const uppy = Uppy()
- const dash = mount((
- <DashboardModal
- uppy={uppy}
- open={false}
- />
- ))
- const { plugin } = dash.instance()
- expect(plugin.openModal).not.toHaveBeenCalled()
- dash.setProps({ open: true })
- expect(plugin.openModal).toHaveBeenCalled()
- dash.unmount()
- })
- it('closes the modal using the `open={false}` prop', () => {
- const uppy = Uppy()
- const dash = mount((
- <DashboardModal
- uppy={uppy}
- open
- />
- ))
- const { plugin } = dash.instance()
- expect(plugin.openModal).toHaveBeenCalled()
- expect(plugin.closeModal).not.toHaveBeenCalled()
- dash.setProps({ open: false })
- expect(plugin.closeModal).toHaveBeenCalled()
- dash.unmount()
- })
- })
|