admin-fe/test/views/reports/index.test.js

53 lines
1.3 KiB
JavaScript
Raw Normal View History

2019-04-03 15:29:33 +00:00
import Vuex from 'vuex'
import { mount, createLocalVue, config } from '@vue/test-utils'
import Element from 'element-ui'
import Reports from '@/views/reports/index'
import storeConfig from './store.conf'
import { cloneDeep } from 'lodash'
import flushPromises from 'flush-promises'
2019-04-03 15:29:33 +00:00
config.mocks["$t"] = () => {}
config.stubs['reports-filter'] = '<div />'
config.stubs['timeline-item'] = '<div />'
2019-04-03 15:29:33 +00:00
const localVue = createLocalVue()
localVue.use(Vuex)
localVue.use(Element)
jest.mock('@/api/reports')
2019-04-03 15:29:33 +00:00
describe('Reports', () => {
let store
beforeEach(() => {
store = new Vuex.Store(cloneDeep(storeConfig))
})
it('initially fetches reports', async (done) => {
const wrapper = mount(Reports, {
store,
localVue
})
await flushPromises()
2019-04-03 15:29:33 +00:00
const initialReports = store.state.reports.fetchedReports.length
expect(initialReports).toEqual(5)
2019-04-03 15:29:33 +00:00
done()
})
2019-04-03 15:42:44 +00:00
it('loads more reports on scroll', async (done) => {
2019-04-03 15:42:44 +00:00
const wrapper = mount(Reports, {
store,
localVue
})
await flushPromises()
expect(store.state.reports.fetchedReports.length).toEqual(5)
window.dispatchEvent(new CustomEvent('scroll', { detail: 2000 }))
await flushPromises()
expect(store.state.reports.fetchedReports.length).toEqual(7)
done()
})
2019-04-03 15:29:33 +00:00
})