在使用Jest进行Vue.js应用的单元测试时,确保每个测试之间的环境是干净且隔离的非常重要。这意味着每个测试运行前,Vue组件的状态、实例和可能的全局配置(如Vuex store、路由等)都应该是重置的。这样可以避免一个测试的副作用影响到另一个测试,从而保证测试结果的准确性和可靠性。
beforeEach
和afterEach
钩子中创建和销毁组件来实现。import { shallowMount } from '@vue/test-utils'; import MyComponent from '@/components/MyComponent.vue'; let wrapper; beforeEach(() => { wrapper = shallowMount(MyComponent); }); afterEach(() => { wrapper.destroy(); }); test('example test', () => { expect(wrapper.text()).toContain('some text'); });
import { createLocalVue, shallowMount } from '@vue/test-utils'; import Vuex from 'vuex'; import MyComponent from '@/components/MyComponent.vue'; const localVue = createLocalVue(); localVue.use(Vuex); let store; let wrapper; beforeEach(() => { store = new Vuex.Store({ state: { /* some state */ } }); wrapper = shallowMount(MyComponent, { store, localVue }); }); afterEach(() => { wrapper.destroy(); }); test('Vuex test', () => { expect(wrapper.vm.$store.state).toBeDefined(); });
window
或document
,或者外部API,你应该在每个测试中使用mocks来隔离这些依赖。Jest提供了全面的mocking工具来帮助你实现这一点。beforeEach(() => { jest.spyOn(window, 'alert').mockImplementation(() => {}); }); afterEach(() => { jest.restoreAllMocks(); }); test('window alert called', () => { // 触发alert expect(window.alert).toHaveBeenCalled(); });
领取专属 10元无门槛券
手把手带您无忧上云