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')
|
2020-10-12 20:39:12 +00:00
|
|
|
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()
|
|
|
|
|
2020-03-21 17:33:13 +00:00
|
|
|
wrapper.setData({ createTokenDialogVisible: false })
|
2019-09-23 19:00:28 +00:00
|
|
|
const openDialogButton = wrapper.find('button.create-invite-token')
|
2020-03-21 17:33:13 +00:00
|
|
|
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()
|
2020-03-21 17:33:13 +00:00
|
|
|
expect(wrapper.vm.createTokenDialogVisible).toBe(true)
|
2019-09-23 19:00:28 +00:00
|
|
|
|
|
|
|
closeDialogButton.trigger('click')
|
|
|
|
await flushPromises()
|
2020-03-21 17:33:13 +00:00
|
|
|
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()
|
|
|
|
})
|
|
|
|
})
|