mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
I also removed one frontend test. The test case was checking an edge case. We use `hasMore` as the single source of truth so I think it's safe to remove this test case.
165 lines
4.4 KiB
JavaScript
165 lines
4.4 KiB
JavaScript
import { config, mount, createLocalVue } from '@vue/test-utils'
|
|
import ProfileSlug from './_slug.vue'
|
|
import Vuex from 'vuex'
|
|
import Styleguide from '@human-connection/styleguide'
|
|
import Filters from '~/plugins/vue-filters'
|
|
import InfiniteLoading from '~/plugins/vue-infinite-loading'
|
|
|
|
const localVue = createLocalVue()
|
|
|
|
localVue.use(Vuex)
|
|
localVue.use(Styleguide)
|
|
localVue.use(Filters)
|
|
localVue.use(InfiniteLoading)
|
|
localVue.filter('date', d => d)
|
|
|
|
config.stubs['client-only'] = '<span><slot /></span>'
|
|
config.stubs['v-popover'] = '<span><slot /></span>'
|
|
config.stubs['nuxt-link'] = '<span><slot /></span>'
|
|
config.stubs['infinite-loading'] = '<span><slot /></span>'
|
|
|
|
describe('ProfileSlug', () => {
|
|
let wrapper
|
|
let Wrapper
|
|
let mocks
|
|
|
|
beforeEach(() => {
|
|
mocks = {
|
|
post: {
|
|
id: 'p23',
|
|
name: 'It is a post',
|
|
},
|
|
$t: jest.fn(),
|
|
// If you're mocking router, then don't use VueRouter with localVue: https://vue-test-utils.vuejs.org/guides/using-with-vue-router.html
|
|
$route: {
|
|
params: {
|
|
id: '4711',
|
|
slug: 'john-doe',
|
|
},
|
|
},
|
|
$router: {
|
|
history: {
|
|
push: jest.fn(),
|
|
},
|
|
},
|
|
$toast: {
|
|
success: jest.fn(),
|
|
error: jest.fn(),
|
|
},
|
|
$apollo: {
|
|
loading: false,
|
|
mutate: jest.fn().mockResolvedValue(),
|
|
},
|
|
}
|
|
})
|
|
|
|
describe('mount', () => {
|
|
Wrapper = () => {
|
|
return mount(ProfileSlug, {
|
|
mocks,
|
|
localVue,
|
|
})
|
|
}
|
|
|
|
describe('given an authenticated user', () => {
|
|
beforeEach(() => {
|
|
mocks.$filters = {
|
|
removeLinks: c => c,
|
|
truncate: a => a,
|
|
}
|
|
mocks.$store = {
|
|
getters: {
|
|
'auth/isModerator': () => false,
|
|
'auth/user': {
|
|
id: 'u23',
|
|
},
|
|
},
|
|
}
|
|
})
|
|
|
|
describe('given a user for the profile', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper()
|
|
wrapper.setData({
|
|
User: [
|
|
{
|
|
id: 'u3',
|
|
name: 'Bob the builder',
|
|
contributionsCount: 6,
|
|
shoutedCount: 7,
|
|
commentedCount: 8,
|
|
},
|
|
],
|
|
})
|
|
})
|
|
|
|
it('displays name of the user', () => {
|
|
expect(wrapper.text()).toContain('Bob the builder')
|
|
})
|
|
|
|
describe('load more button', () => {
|
|
const aPost = {
|
|
title: 'I am a post',
|
|
content: 'This is my content',
|
|
contentExcerpt: 'This is my content',
|
|
}
|
|
|
|
describe('currently no posts available (e.g. after tab switching)', () => {
|
|
beforeEach(() => {
|
|
wrapper.setData({ posts: [], hasMore: false })
|
|
})
|
|
|
|
it('displays no "load more" button', () => {
|
|
expect(wrapper.find('.load-more').exists()).toBe(false)
|
|
})
|
|
|
|
describe('apollo client in `loading` state', () => {
|
|
beforeEach(() => {
|
|
wrapper.vm.$apollo.loading = true
|
|
})
|
|
|
|
it('never displays more than one loading spinner', () => {
|
|
expect(wrapper.findAll('.ds-spinner')).toHaveLength(1)
|
|
})
|
|
|
|
it('displays a loading spinner below the posts list', () => {
|
|
expect(wrapper.find('.user-profile-posts-list .ds-spinner').exists()).toBe(true)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('pagination returned at least as many posts as pageSize', () => {
|
|
beforeEach(() => {
|
|
const posts = [1, 2, 3, 4, 5, 6].map(id => {
|
|
return {
|
|
...aPost,
|
|
id,
|
|
}
|
|
})
|
|
wrapper.setData({ posts })
|
|
})
|
|
|
|
it('displays "load more" button', () => {
|
|
expect(wrapper.find('.load-more').exists()).toBe(true)
|
|
})
|
|
|
|
describe('apollo client in `loading` state', () => {
|
|
beforeEach(() => {
|
|
wrapper.vm.$apollo.loading = true
|
|
})
|
|
|
|
it('never displays more than one loading spinner', () => {
|
|
expect(wrapper.findAll('.ds-spinner')).toHaveLength(1)
|
|
})
|
|
|
|
it('displays a loading spinner below the posts list', () => {
|
|
expect(wrapper.find('.load-more .ds-spinner').exists()).toBe(true)
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|