import { mount } from '@vue/test-utils'; import Vue from 'vue'; import Modal from '..'; const ModalTester = { props: ['footer', 'visible'], methods: { getContainer() { return this.$refs.container; }, }, render() { const modalProps = { props: { ...this.$props, getContainer: this.getContainer, }, }; return (
Here is content of Modal
); }, }; describe('Modal', () => { it('render correctly', done => { const wrapper = mount({ render() { return ; }, }); expect(wrapper.html()).toMatchSnapshot(); // https://github.com/vuejs/vue-test-utils/issues/624 const wrapper1 = mount(ModalTester, { sync: false, }); wrapper1.setProps({ visible: true }); Vue.nextTick(() => { expect(wrapper1.html()).toMatchSnapshot(); done(); }); }); it('render without footer', () => { const wrapper = mount({ render() { return ; }, }); expect(wrapper.html()).toMatchSnapshot(); }); });