import { expect } from 'chai' import sinon from 'sinon' import { shallowMount } from '@vue/test-utils' import Vuex from 'vuex' import App from '@/App' import storedInquiries from '@/lib/storedInquiries' import mutations from '@/store/mutations' describe('App.vue', () => { afterEach(() => { sinon.restore() }) it('Gets inquiries', () => { sinon.stub(storedInquiries, 'getStoredInquiries').returns([ { id: 1 }, { id: 2 }, { id: 3 } ]) const state = { predefinedInquiries: [], inquiries: [] } const store = new Vuex.Store({ state, mutations }) shallowMount(App, { store, stubs: ['router-view'] }) expect(state.inquiries).to.eql([{ id: 1 }, { id: 2 }, { id: 3 }]) }) it('Updates inquiries when they change in store', async () => { sinon.stub(storedInquiries, 'getStoredInquiries').returns([ { id: 1, name: 'foo' }, { id: 2, name: 'baz' }, { id: 3, name: 'bar' } ]) sinon.spy(storedInquiries, 'updateStorage') const state = { predefinedInquiries: [], inquiries: [] } const store = new Vuex.Store({ state, mutations }) const wrapper = shallowMount(App, { store, stubs: ['router-view'] }) store.state.inquiries.splice(0, 1, { id: 1, name: 'new foo name' }) await wrapper.vm.$nextTick() expect(storedInquiries.updateStorage.calledTwice).to.equal(true) expect(storedInquiries.updateStorage.args[1][0]).to.eql([ { id: 1, name: 'new foo name' }, { id: 2, name: 'baz' }, { id: 3, name: 'bar' } ]) }) })