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

127 lines
3.5 KiB
JavaScript
Raw Permalink Normal View History

2019-09-23 19:00:28 +00:00
import Vuex from 'vuex'
2020-09-18 22:46:37 +00:00
import { mount, createLocalVue, config, RouterLinkStub } from '@vue/test-utils'
2019-09-23 19:00:28 +00:00
import flushPromises from 'flush-promises'
import Element from 'element-ui'
import Invites from '@/views/invites/index'
import storeConfig from './store.conf'
import { cloneDeep } from 'lodash'
config.mocks["$t"] = () => {}
const localVue = createLocalVue()
localVue.use(Vuex)
localVue.use(Element)
2020-04-17 22:27:00 +00:00
jest.mock('@/api/app')
2019-09-23 19:00:28 +00:00
jest.mock('@/api/invites')
2020-04-17 22:27:00 +00:00
jest.mock('@/api/nodeInfo')
jest.mock('@/api/settings')
2019-09-23 19:00:28 +00:00
describe('Invite tokens', () => {
let store
beforeEach(() => {
store = new Vuex.Store(cloneDeep(storeConfig))
})
it('fetches initial list of invtie tokens', async (done) => {
mount(Invites, {
store,
localVue,
sync: false,
2020-09-18 22:46:37 +00:00
stubs: {
RouterLink: RouterLinkStub
}
2019-09-23 19:00:28 +00:00
})
await flushPromises()
const inviteTokens = store.state.invites.inviteTokens
expect(inviteTokens.length).toEqual(3)
done()
})
it('opens and closes dialog window', async (done) => {
const wrapper = mount(Invites, {
store,
localVue,
sync: false,
2020-09-18 22:46:37 +00:00
stubs: {
RouterLink: RouterLinkStub
}
2019-09-23 19:00:28 +00:00
})
await flushPromises()
wrapper.setData({ createTokenDialogVisible: false })
2019-09-23 19:00:28 +00:00
const openDialogButton = wrapper.find('button.create-invite-token')
const closeDialogButton = wrapper.find('div.el-dialog__footer button.invites-close-dialog')
expect(wrapper.vm.createTokenDialogVisible).toBe(false)
2019-09-23 19:00:28 +00:00
openDialogButton.trigger('click')
await flushPromises()
expect(wrapper.vm.createTokenDialogVisible).toBe(true)
2019-09-23 19:00:28 +00:00
closeDialogButton.trigger('click')
await flushPromises()
expect(wrapper.vm.createTokenDialogVisible).toBe(false)
2019-09-23 19:00:28 +00:00
done()
})
it('generates new invtie token', async (done) => {
const wrapper = mount(Invites, {
store,
localVue,
sync: false,
2020-09-18 22:46:37 +00:00
stubs: {
RouterLink: RouterLinkStub
}
2019-09-23 19:00:28 +00:00
})
await flushPromises()
expect(store.state.invites.inviteTokens.length).toEqual(3)
expect(Object.keys(store.state.invites.newToken).length).toEqual(0)
const openDialogButton = wrapper.find('button.create-invite-token')
openDialogButton.trigger('click')
await flushPromises()
const maxUseInput = wrapper.find('input[name="maxUse"]')
maxUseInput.element.value = 3
maxUseInput.trigger('input')
const expireDate = wrapper.find('input[name="date"]')
expireDate.element.value = '2019-04-10'
expireDate.trigger('input')
const createButton = wrapper.find('.create-new-token-dialog button.el-button--primary')
createButton.trigger('click')
await flushPromises()
expect(store.state.invites.inviteTokens.length).toEqual(4)
expect(Object.keys(store.state.invites.newToken).length).toEqual(3)
expect(store.state.invites.newToken.token).toEqual('JYl0SjXW8t-t-pLSZBnZLf6PwjCW-qy6Dq70jfUOuqk=')
expect(store.state.invites.newToken.expiresAt).toEqual('2019-04-10')
expect(store.state.invites.newToken.maxUse).toEqual(3)
done()
})
it('revokes invite token', async (done) => {
const wrapper = mount(Invites, {
store,
localVue,
sync: false,
2020-09-18 22:46:37 +00:00
stubs: {
RouterLink: RouterLinkStub
}
2019-09-23 19:00:28 +00:00
})
await flushPromises()
expect(store.state.invites.inviteTokens[3].used).toBe(false)
const revokeButton = wrapper.find('table tr button')
revokeButton.trigger('click')
await flushPromises()
expect(store.state.invites.inviteTokens[0].used).toBe(true)
done()
})
})