blessing-skin-server/resources/assets/tests/views/user/Dashboard.test.ts

169 lines
4.5 KiB
TypeScript
Raw Normal View History

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-26 09:44:04 +08:00
import { Button } from 'element-ui'
2019-03-18 15:00:18 +08:00
import Dashboard from '@/views/user/Dashboard.vue'
2018-08-08 09:50:35 +08:00
2019-03-26 09:44:04 +08:00
jest.mock('@tweenjs/tween.js', () => ({
Tween: class <T> {
data: T
constructor(data: T) {
this.data = data
}
to(data: Partial<T>, _: number) {
Object.assign(this.data, data)
return this
}
start() {}
},
update() {},
}))
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 {
2019-04-23 19:14:41 +08:00
data: {
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,
},
2019-03-15 11:42:41 +08:00
},
2019-04-23 19:14:41 +08:00
signAfterZero: false,
signGapTime: '24',
...data,
2019-03-15 11:42:41 +08:00
},
}
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')
})
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')
wrapper = mount(Dashboard)
await wrapper.vm.$nextTick()
expect(wrapper.text()).toContain('2 / 4 MB')
})
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()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).attributes('disabled')).toBeNil()
2019-03-15 11:42:41 +08:00
wrapper = mount(Dashboard)
await wrapper.vm.$nextTick()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).attributes('disabled')).toBe('disabled')
2019-03-15 11:42:41 +08:00
wrapper = mount(Dashboard)
await wrapper.vm.$nextTick()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).attributes('disabled')).toBeNil()
2019-03-15 11:42:41 +08:00
wrapper = mount(Dashboard)
await wrapper.vm.$nextTick()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).attributes('disabled')).toBe('disabled')
2019-03-15 11:42:41 +08:00
})
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()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).text()).toMatch(/(29)|(30)/)
expect(wrapper.find(Button).text()).toContain('min')
2019-03-15 11:42:41 +08:00
wrapper = mount(Dashboard)
await wrapper.vm.$nextTick()
2019-03-26 09:44:04 +08:00
expect(wrapper.find(Button).text()).toContain('23')
expect(wrapper.find(Button).text()).toContain('hour')
2019-03-15 11:42:41 +08:00
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
Vue.prototype.$http.get.mockResolvedValue(scoreInfo({
user: { lastSignAt: Date.now() - 30 * 3600 * 1000 },
}))
Vue.prototype.$http.post
2019-04-23 19:14:41 +08:00
.mockResolvedValueOnce({
code: 1, message: '1', data: {},
})
2019-03-15 11:42:41 +08:00
.mockResolvedValueOnce({
2019-04-23 11:47:45 +08:00
code: 0,
2019-04-23 19:14:41 +08:00
data: {
score: 233,
storage: { used: 3, total: 4 },
},
2019-03-15 11:42:41 +08:00
})
const wrapper = mount(Dashboard)
2019-03-26 09:44:04 +08:00
const button = wrapper.find(Button)
2019-03-15 11:42:41 +08:00
await wrapper.vm.$nextTick()
button.trigger('click')
await wrapper.vm.$nextTick()
expect(Vue.prototype.$http.post).toBeCalledWith('/user/sign')
2019-03-25 22:01:57 +08:00
expect(Vue.prototype.$message.warning).toBeCalledWith('1')
2019-03-15 11:42:41 +08:00
button.trigger('click')
await wrapper.vm.$nextTick()
expect(button.attributes('disabled')).toBe('disabled')
expect(wrapper.text()).toContain('3 / 4 KB')
})