2020-05-24 18:14:58 +00:00
|
|
|
import Vuex from 'vuex'
|
|
|
|
import { mount, createLocalVue, config } from '@vue/test-utils'
|
|
|
|
import flushPromises from 'flush-promises'
|
|
|
|
import Element from 'element-ui'
|
|
|
|
import StatusShow from '@/views/statuses/show'
|
|
|
|
import storeConfig from './statusShowStore.conf'
|
|
|
|
import { cloneDeep } from 'lodash'
|
|
|
|
|
|
|
|
config.mocks["$t"] = () => {}
|
|
|
|
|
|
|
|
const localVue = createLocalVue()
|
|
|
|
localVue.use(Vuex)
|
|
|
|
localVue.use(Element)
|
|
|
|
|
|
|
|
const $route = {
|
|
|
|
params: {
|
|
|
|
id: '9vJOO3iFPyjNaEhJ5s'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
jest.mock('@/api/app')
|
|
|
|
jest.mock('@/api/status')
|
|
|
|
jest.mock('@/api/peers')
|
|
|
|
jest.mock('@/api/nodeInfo')
|
2020-05-26 19:38:03 +00:00
|
|
|
jest.mock('@/api/users')
|
2020-05-24 18:14:58 +00:00
|
|
|
|
|
|
|
describe('Status show page', () => {
|
|
|
|
let store
|
|
|
|
|
|
|
|
beforeEach(() => {
|
|
|
|
store = new Vuex.Store(cloneDeep(storeConfig))
|
|
|
|
})
|
|
|
|
|
2020-05-26 19:38:03 +00:00
|
|
|
it(`fetches single status and user's statuses`, async (done) => {
|
2020-05-24 18:14:58 +00:00
|
|
|
const wrapper = mount(StatusShow, {
|
|
|
|
store,
|
|
|
|
localVue,
|
|
|
|
sync: false,
|
|
|
|
stubs: ['router-link'],
|
|
|
|
mocks: {
|
|
|
|
$route
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await flushPromises()
|
|
|
|
|
|
|
|
expect(wrapper.find('.status-container').isVisible()).toBe(true)
|
|
|
|
expect(store.state.status.fetchedStatus.id).toBe('9vJOO3iFPyjNaEhJ5s')
|
2020-06-06 21:37:28 +00:00
|
|
|
expect(store.state.status.fetchedStatus.account.nickname).toBe('dolin')
|
2020-05-26 19:38:03 +00:00
|
|
|
expect(store.state.userProfile.statuses.length).toEqual(3)
|
2020-05-24 18:14:58 +00:00
|
|
|
done()
|
|
|
|
})
|
2020-05-26 22:44:26 +00:00
|
|
|
|
|
|
|
it(`renders links and user's moderation menu`, async (done) => {
|
|
|
|
const wrapper = mount(StatusShow, {
|
|
|
|
store,
|
|
|
|
localVue,
|
|
|
|
sync: false,
|
|
|
|
stubs: ['router-link'],
|
|
|
|
mocks: {
|
|
|
|
$route
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await flushPromises()
|
|
|
|
|
|
|
|
expect(wrapper.find('router-link-stub h1').text()).toBe('dolin')
|
|
|
|
expect(wrapper.find('button.moderate-user-button').exists()).toBe(true)
|
|
|
|
expect(wrapper.find('.el-dropdown-menu').exists()).toBe(true)
|
|
|
|
done()
|
|
|
|
})
|
|
|
|
|
|
|
|
it(`renders status card`, async (done) => {
|
|
|
|
const wrapper = mount(StatusShow, {
|
|
|
|
store,
|
|
|
|
localVue,
|
|
|
|
sync: false,
|
|
|
|
stubs: ['router-link'],
|
|
|
|
mocks: {
|
|
|
|
$route
|
|
|
|
}
|
|
|
|
})
|
|
|
|
await flushPromises()
|
|
|
|
|
|
|
|
expect(wrapper.find('.status-card').exists()).toBe(true)
|
2020-06-06 21:37:28 +00:00
|
|
|
expect(wrapper.find('router-link-stub span.status-account-name').text()).toBe('dolin')
|
2020-05-26 22:44:26 +00:00
|
|
|
expect(wrapper.find('span.el-tag').text()).not.toBe('Sensitive')
|
|
|
|
expect(wrapper.find('span.el-tag').text()).toBe('Public')
|
|
|
|
expect(wrapper.find('button.status-actions-button').exists()).toBe(true)
|
|
|
|
expect(wrapper.find('.status-body .status-content').text()).toBe('pizza makes everything better')
|
|
|
|
done()
|
|
|
|
})
|
2020-05-24 18:14:58 +00:00
|
|
|
})
|