157 lines
4.4 KiB
JavaScript
157 lines
4.4 KiB
JavaScript
import Vuex from 'vuex'
|
|
import { mount, createLocalVue, config } from '@vue/test-utils'
|
|
import Element from 'element-ui'
|
|
import TimelineItem from '@/views/reports/components/TimelineItem'
|
|
import storeConfig from './store.conf'
|
|
import { cloneDeep } from 'lodash'
|
|
import flushPromises from 'flush-promises'
|
|
|
|
config.mocks["$t"] = () => {}
|
|
|
|
const localVue = createLocalVue()
|
|
localVue.use(Vuex)
|
|
localVue.use(Element)
|
|
|
|
jest.mock('@/api/reports')
|
|
|
|
describe('Report in a timeline', () => {
|
|
let store
|
|
|
|
beforeEach(async() => {
|
|
store = new Vuex.Store(cloneDeep(storeConfig))
|
|
store.dispatch('FetchReports')
|
|
await flushPromises()
|
|
})
|
|
|
|
it('changes report state from open to resolved', async (done) => {
|
|
const report = store.state.reports.fetchedReports[0]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.state).toBe('open')
|
|
|
|
const button = wrapper.find(`li.el-dropdown-menu__item:nth-child(${1})`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[0].state).toBe('resolved')
|
|
done()
|
|
})
|
|
|
|
it('changes report state from open to closed', async (done) => {
|
|
const report = store.state.reports.fetchedReports[3]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.state).toBe('open')
|
|
|
|
const button = wrapper.find(`li.el-dropdown-menu__item:nth-child(${2})`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[3].state).toBe('closed')
|
|
done()
|
|
})
|
|
|
|
it('shows statuses', () => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
|
|
const statuses = wrapper.findAll(`.status-card`)
|
|
expect(statuses.length).toEqual(2)
|
|
})
|
|
|
|
it('adds sensitive flag to a status', async (done) => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.statuses[0].sensitive).toBe(false)
|
|
|
|
const button = wrapper.find(`.status-card li.el-dropdown-menu__item`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[4].statuses[0].sensitive).toEqual(true)
|
|
done()
|
|
})
|
|
|
|
it('removes sensitive flag to a status', async (done) => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.statuses[1].sensitive).toBe(true)
|
|
|
|
const button = wrapper.find(`.status-card:nth-child(${2}) li.el-dropdown-menu__item`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[4].statuses[1].sensitive).toEqual(false)
|
|
done()
|
|
})
|
|
|
|
it('changes status visibility from public to unlisted', async (done) => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.statuses[0].visibility).toBe('public')
|
|
|
|
const button = wrapper.find(`.status-card li.el-dropdown-menu__item:nth-child(${3})`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[4].statuses[0].visibility).toEqual('unlisted')
|
|
done()
|
|
})
|
|
|
|
it('changes status visibility from unlisted to private', async (done) => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
const wrapper = mount(TimelineItem, {
|
|
store,
|
|
localVue,
|
|
propsData: {
|
|
report: report
|
|
}
|
|
})
|
|
expect(report.statuses[1].visibility).toBe('unlisted')
|
|
|
|
const button = wrapper.find(`.status-card:nth-child(${2}) li.el-dropdown-menu__item:nth-child(${3})`)
|
|
button.trigger('click')
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[4].statuses[1].visibility).toEqual('private')
|
|
done()
|
|
})
|
|
|
|
it('deletes a status', async (done) => {
|
|
const report = store.state.reports.fetchedReports[4]
|
|
expect(report.statuses.length).toEqual(2)
|
|
|
|
store.dispatch('DeleteStatus', { statusId: '11', reportId: '7'})
|
|
await flushPromises()
|
|
expect(store.state.reports.fetchedReports[4].statuses.length).toEqual(1)
|
|
done()
|
|
})
|
|
})
|