mirror of
https://github.com/Ocelot-Social-Community/Ocelot-Social.git
synced 2025-12-13 07:46:06 +00:00
- New badge UI, including editor. - Adds config to enable/disable badges. --------- Co-authored-by: Sebastian Stein <sebastian@codepassion.de> Co-authored-by: Maximilian Harz <maxharz@gmail.com>
198 lines
4.4 KiB
JavaScript
198 lines
4.4 KiB
JavaScript
import { render } from '@testing-library/vue'
|
|
import ProfileSlug from './_slug.vue'
|
|
|
|
const localVue = global.localVue
|
|
|
|
localVue.filter('date', (d) => d)
|
|
|
|
// Mock Math.random, used in Dropdown
|
|
Object.assign(Math, {
|
|
random: () => 0,
|
|
})
|
|
|
|
const stubs = {
|
|
'client-only': true,
|
|
'v-popover': true,
|
|
'nuxt-link': true,
|
|
'follow-list': true,
|
|
'router-link': true,
|
|
}
|
|
|
|
describe('ProfileSlug', () => {
|
|
let wrapper
|
|
let mocks
|
|
|
|
beforeEach(() => {
|
|
mocks = {
|
|
post: {
|
|
id: 'p23',
|
|
name: 'It is a post',
|
|
},
|
|
$t: jest.fn((t) => t),
|
|
// 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(),
|
|
},
|
|
}
|
|
})
|
|
|
|
const Wrapper = (badgesEnabled, data) => {
|
|
return render(ProfileSlug, {
|
|
localVue,
|
|
stubs,
|
|
data: () => data,
|
|
mocks: {
|
|
...mocks,
|
|
$env: {
|
|
BADGES_ENABLED: badgesEnabled,
|
|
},
|
|
},
|
|
})
|
|
}
|
|
|
|
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 another profile user', () => {
|
|
const user = {
|
|
User: [
|
|
{
|
|
id: 'u3',
|
|
name: 'Bob the builder',
|
|
contributionsCount: 6,
|
|
shoutedCount: 7,
|
|
commentedCount: 8,
|
|
badgeVerification: {
|
|
id: 'bv1',
|
|
icon: '/path/to/icon-bv1',
|
|
description: 'verified',
|
|
isDefault: false,
|
|
},
|
|
badgeTrophiesSelected: [
|
|
{
|
|
id: 'bt1',
|
|
icon: '/path/to/icon-bt1',
|
|
description: 'a trophy',
|
|
isDefault: false,
|
|
},
|
|
{
|
|
id: 'bt2',
|
|
icon: '/path/to/icon-bt2',
|
|
description: 'no trophy',
|
|
isDefault: true,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
}
|
|
|
|
describe('and badges are enabled', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper(true, user)
|
|
})
|
|
|
|
it('renders', () => {
|
|
expect(wrapper.container).toMatchSnapshot()
|
|
})
|
|
})
|
|
|
|
describe('and badges are disabled', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper(false, user)
|
|
})
|
|
|
|
it('renders', () => {
|
|
expect(wrapper.container).toMatchSnapshot()
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('given the logged in user as profile user', () => {
|
|
beforeEach(() => {
|
|
mocks.$route.params.id = 'u23'
|
|
})
|
|
|
|
const user = {
|
|
User: [
|
|
{
|
|
id: 'u23',
|
|
name: 'Bob the builder',
|
|
contributionsCount: 6,
|
|
shoutedCount: 7,
|
|
commentedCount: 8,
|
|
badgeVerification: {
|
|
id: 'bv1',
|
|
icon: '/path/to/icon-bv1',
|
|
description: 'verified',
|
|
isDefault: false,
|
|
},
|
|
badgeTrophiesSelected: [
|
|
{
|
|
id: 'bt1',
|
|
icon: '/path/to/icon-bt1',
|
|
description: 'a trophy',
|
|
isDefault: false,
|
|
},
|
|
{
|
|
id: 'bt2',
|
|
icon: '/path/to/icon-bt2',
|
|
description: 'no trophy',
|
|
isDefault: true,
|
|
},
|
|
],
|
|
},
|
|
],
|
|
}
|
|
|
|
describe('and badges are enabled', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper(true, user)
|
|
})
|
|
|
|
it('renders', () => {
|
|
expect(wrapper.container).toMatchSnapshot()
|
|
})
|
|
})
|
|
|
|
describe('and badges are disabled', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper(false, user)
|
|
})
|
|
|
|
it('renders', () => {
|
|
expect(wrapper.container).toMatchSnapshot()
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|