2019-03-15 11:42:41 +08:00
|
|
|
/* eslint-disable no-mixed-operators */
|
|
|
|
import Vue from 'vue'
|
|
|
|
import { mount } from '@vue/test-utils'
|
2019-03-18 09:55:24 +08:00
|
|
|
import Dashboard from '@/components/user/Dashboard.vue'
|
2019-03-15 11:42:41 +08:00
|
|
|
import toastr from 'toastr'
|
|
|
|
import { swal } from '@/js/notify'
|
2018-08-08 09:50:35 +08:00
|
|
|
|
2019-03-15 11:42:41 +08:00
|
|
|
jest.mock('@/js/notify')
|
2018-08-08 09:50:35 +08:00
|
|
|
|
2019-03-15 11:42:41 +08:00
|
|
|
window.blessing.extra = { unverified: false }
|
2018-08-17 12:32:44 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
function scoreInfo(data = {}) {
|
2019-03-15 11:42:41 +08:00
|
|
|
return {
|
|
|
|
user: { score: 835, lastSignAt: '2018-08-07 16:06:49' },
|
|
|
|
stats: {
|
|
|
|
players: {
|
|
|
|
used: 3, total: 15, percentage: 20,
|
|
|
|
},
|
|
|
|
storage: {
|
|
|
|
used: 5, total: 20, percentage: 25,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
signAfterZero: false,
|
|
|
|
signGapTime: '24',
|
|
|
|
...data,
|
|
|
|
}
|
2018-08-08 09:50:35 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
test('fetch score info', () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get.mockResolvedValue(scoreInfo())
|
|
|
|
mount(Dashboard)
|
|
|
|
expect(Vue.prototype.$http.get).toBeCalledWith('/user/score-info')
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('players usage', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get.mockResolvedValue(scoreInfo())
|
|
|
|
const wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.text()).toContain('3 / 15')
|
|
|
|
expect(wrapper.find('.progress-bar-aqua').attributes('style')).toBe('width: 20%;')
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('storage usage', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get
|
|
|
|
.mockResolvedValueOnce(scoreInfo())
|
|
|
|
.mockResolvedValueOnce(scoreInfo({
|
|
|
|
stats: {
|
|
|
|
players: {
|
|
|
|
used: 3, total: 15, percentage: 20,
|
|
|
|
},
|
|
|
|
storage: {
|
|
|
|
used: 2048, total: 4096, percentage: 50,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
}))
|
|
|
|
let wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.text()).toContain('5 / 20 KB')
|
|
|
|
expect(wrapper.find('.progress-bar-yellow').attributes('style')).toBe('width: 25%;')
|
|
|
|
|
|
|
|
wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.text()).toContain('2 / 4 MB')
|
|
|
|
expect(wrapper.find('.progress-bar-yellow').attributes('style')).toBe('width: 50%;')
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('display score', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get.mockResolvedValue(scoreInfo())
|
|
|
|
const wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('#score').text()).toContain('835')
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('button `sign` state', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get
|
|
|
|
.mockResolvedValueOnce(scoreInfo({ signAfterZero: true }))
|
|
|
|
.mockResolvedValueOnce(scoreInfo({
|
|
|
|
signAfterZero: true,
|
|
|
|
user: { lastSignAt: Date.now() },
|
|
|
|
}))
|
|
|
|
.mockResolvedValueOnce(scoreInfo({ user: { lastSignAt: Date.now() - 25 * 3600 * 1000 } }))
|
|
|
|
.mockResolvedValueOnce(scoreInfo({ user: { lastSignAt: Date.now() } }))
|
|
|
|
|
|
|
|
let wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').attributes('disabled')).toBeNil()
|
|
|
|
|
|
|
|
wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').attributes('disabled')).toBe('disabled')
|
|
|
|
|
|
|
|
wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').attributes('disabled')).toBeNil()
|
|
|
|
|
|
|
|
wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').attributes('disabled')).toBe('disabled')
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('remaining time', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
const origin = Vue.prototype.$t
|
|
|
|
Vue.prototype.$t = (key, args) => key + JSON.stringify(args)
|
|
|
|
|
|
|
|
Vue.prototype.$http.get
|
|
|
|
.mockResolvedValueOnce(scoreInfo({
|
|
|
|
user: { lastSignAt: Date.now() - 23.5 * 3600 * 1000 },
|
|
|
|
}))
|
|
|
|
.mockResolvedValueOnce(scoreInfo({
|
|
|
|
user: { lastSignAt: Date.now() },
|
|
|
|
}))
|
|
|
|
|
|
|
|
let wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').text()).toMatch(/(29)|(30)/)
|
|
|
|
expect(wrapper.find('button').text()).toContain('min')
|
|
|
|
|
|
|
|
wrapper = mount(Dashboard)
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(wrapper.find('button').text()).toContain('23')
|
|
|
|
expect(wrapper.find('button').text()).toContain('hour')
|
|
|
|
|
|
|
|
Vue.prototype.$t = origin
|
|
|
|
})
|
2019-03-17 10:21:18 +08:00
|
|
|
|
2018-08-08 09:50:35 +08:00
|
|
|
test('sign', async () => {
|
2019-03-15 11:42:41 +08:00
|
|
|
jest.spyOn(toastr, 'warning')
|
2019-03-18 09:55:24 +08:00
|
|
|
swal.mockResolvedValue({})
|
2019-03-15 11:42:41 +08:00
|
|
|
Vue.prototype.$http.get.mockResolvedValue(scoreInfo({
|
|
|
|
user: { lastSignAt: Date.now() - 30 * 3600 * 1000 },
|
|
|
|
}))
|
|
|
|
Vue.prototype.$http.post
|
|
|
|
.mockResolvedValueOnce({ errno: 1, msg: '1' })
|
|
|
|
.mockResolvedValueOnce({
|
|
|
|
errno: 0,
|
|
|
|
score: 233,
|
|
|
|
storage: { used: 3, total: 4 },
|
|
|
|
})
|
|
|
|
const wrapper = mount(Dashboard)
|
|
|
|
const button = wrapper.find('button')
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
|
|
|
|
button.trigger('click')
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(Vue.prototype.$http.post).toBeCalledWith('/user/sign')
|
|
|
|
expect(toastr.warning).toBeCalledWith('1')
|
|
|
|
|
|
|
|
button.trigger('click')
|
|
|
|
await wrapper.vm.$nextTick()
|
|
|
|
expect(button.attributes('disabled')).toBe('disabled')
|
|
|
|
expect(wrapper.text()).toContain('3 / 4 KB')
|
|
|
|
})
|