2023-02-15 10:23:34 +01:00

178 lines
5.3 KiB
JavaScript

import { mount } from '@vue/test-utils'
import PageFooter from './PageFooter.vue'
import linksDefault from '~/constants/links.js'
const localVue = global.localVue
const stubs = {
'nuxt-link': {
template: '<span class="nuxt-link"><slot /></span>',
},
}
describe('PageFooter.vue', () => {
let mocks
let wrapper
beforeEach(() => {
mocks = {
$t: jest.fn(),
$env: {
VERSION: 'v1.0.0',
},
}
})
describe('mount', () => {
const Wrapper = () => {
return mount(PageFooter, { mocks, localVue, stubs })
}
describe('links.js', () => {
beforeEach(() => {
wrapper = Wrapper()
})
it('renders five links', () => {
expect(wrapper.findAll('a')).toHaveLength(5)
})
it('renders four nuxt-links', () => {
expect(wrapper.findAll('.nuxt-link')).toHaveLength(4)
})
it('renders version', () => {
expect(wrapper.find('.ds-footer').text()).toContain('v1.0.0')
})
})
describe('inflexible links', () => {
beforeEach(() => {
wrapper = Wrapper()
})
it('renders version', () => {
expect(wrapper.find('a[data-test="version-link"]').exists()).toBeTruthy()
})
})
describe('flexible links not set', () => {
beforeEach(async () => {
const links = {
...linksDefault,
ORGANIZATION: linksDefault.ORGANIZATION.overwrite({ externalLink: null }),
IMPRINT: linksDefault.IMPRINT.overwrite({ externalLink: null }),
TERMS_AND_CONDITIONS: linksDefault.TERMS_AND_CONDITIONS.overwrite({ externalLink: null }),
CODE_OF_CONDUCT: linksDefault.CODE_OF_CONDUCT.overwrite({ externalLink: null }),
DATA_PRIVACY: linksDefault.DATA_PRIVACY.overwrite({ externalLink: null }),
FAQ: linksDefault.FAQ.overwrite({ externalLink: null }),
}
wrapper = Wrapper()
wrapper.setData({ links })
await wrapper.vm.$nextTick()
})
it('renders ORGANIZATION as nuxt-link', () => {
expect(wrapper.find('span[data-test="organization-nuxt-link"]').exists()).toBeTruthy()
})
it('renders IMPRINT as nuxt-link', () => {
expect(wrapper.find('span[data-test="imprint-nuxt-link"]').exists()).toBeTruthy()
})
it('renders TERMS_AND_CONDITIONS as nuxt-link', () => {
expect(
wrapper.find('span[data-test="terms-and-conditions-nuxt-link"]').exists(),
).toBeTruthy()
})
it('renders CODE_OF_CONDUCT as nuxt-link', () => {
expect(wrapper.find('span[data-test="code-of-conduct-nuxt-link"]').exists()).toBeTruthy()
})
it('renders DATA_PRIVACY as nuxt-link', () => {
expect(wrapper.find('span[data-test="data-privacy-nuxt-link"]').exists()).toBeTruthy()
})
it('renders FAQ as nuxt-link', () => {
expect(wrapper.find('span[data-test="faq-nuxt-link"]').exists()).toBeTruthy()
})
})
describe('flexible links set', () => {
beforeEach(async () => {
const links = {
...linksDefault,
ORGANIZATION: linksDefault.ORGANIZATION.overwrite({
externalLink: {
url: 'https://ocelot.social',
target: '_blank',
},
}),
IMPRINT: linksDefault.IMPRINT.overwrite({
externalLink: {
url: 'https://ocelot.social/IMPRINT',
target: '_blank',
},
}),
TERMS_AND_CONDITIONS: linksDefault.TERMS_AND_CONDITIONS.overwrite({
externalLink: {
url: 'https://ocelot.social/TERMS_AND_CONDITIONS',
target: '_blank',
},
}),
CODE_OF_CONDUCT: linksDefault.CODE_OF_CONDUCT.overwrite({
externalLink: {
url: 'https://ocelot.social/CODE_OF_CONDUCT',
target: '_blank',
},
}),
DATA_PRIVACY: linksDefault.DATA_PRIVACY.overwrite({
externalLink: {
url: 'https://ocelot.social/DATA_PRIVACY',
target: '_blank',
},
}),
FAQ: linksDefault.FAQ.overwrite({
externalLink: {
url: 'https://ocelot.social/FAQ',
target: '_blank',
},
}),
}
wrapper = Wrapper()
wrapper.setData({ links })
await wrapper.vm.$nextTick()
})
it('renders ORGANIZATION as "a" tag link', () => {
expect(wrapper.find(`a[href="https://ocelot.social"]`).exists()).toBeTruthy()
})
it('renders IMPRINT as "a" tag link', () => {
expect(wrapper.find(`a[href="https://ocelot.social/IMPRINT"]`).exists()).toBeTruthy()
})
it('renders TERMS_AND_CONDITIONS as "a" tag link', () => {
expect(
wrapper.find(`a[href="https://ocelot.social/TERMS_AND_CONDITIONS"]`).exists(),
).toBeTruthy()
})
it('renders CODE_OF_CONDUCT as "a" tag link', () => {
expect(
wrapper.find(`a[href="https://ocelot.social/CODE_OF_CONDUCT"]`).exists(),
).toBeTruthy()
})
it('renders DATA_PRIVACY as "a" tag link', () => {
expect(wrapper.find(`a[href="https://ocelot.social/DATA_PRIVACY"]`).exists()).toBeTruthy()
})
it('renders FAQ as "a" tag link', () => {
expect(wrapper.find(`a[href="https://ocelot.social/FAQ"]`).exists()).toBeTruthy()
})
})
})
})