mirror of
https://github.com/IT4Change/Ocelot-Social.git
synced 2025-12-13 07:45:56 +00:00
182 lines
5.7 KiB
JavaScript
182 lines
5.7 KiB
JavaScript
import { mount } from '@vue/test-utils'
|
|
import NotificationsPage from './index.vue'
|
|
|
|
import DropdownFilter from '~/components/DropdownFilter/DropdownFilter'
|
|
import NotificationsTable from '~/components/NotificationsTable/NotificationsTable'
|
|
import PaginationButtons from '~/components/_new/generic/PaginationButtons/PaginationButtons'
|
|
|
|
import { markAsReadMutation, markAllAsReadMutation } from '~/graphql/User'
|
|
const localVue = global.localVue
|
|
|
|
const stubs = {
|
|
'client-only': true,
|
|
'notifications-table': true,
|
|
}
|
|
|
|
describe('PostIndex', () => {
|
|
let wrapper, Wrapper, mocks
|
|
|
|
beforeEach(() => {
|
|
mocks = {
|
|
$t: (string) => string,
|
|
$toast: {
|
|
error: jest.fn((string) => string),
|
|
},
|
|
$i18n: {
|
|
locale: () => 'en',
|
|
},
|
|
$apollo: {
|
|
mutate: jest.fn().mockResolvedValueOnce({
|
|
data: { markAsRead: { id: 'notificationSourceId', read: true } },
|
|
}),
|
|
queries: {
|
|
notifications: {
|
|
refresh: jest.fn().mockResolvedValueOnce(),
|
|
},
|
|
},
|
|
},
|
|
}
|
|
})
|
|
|
|
describe('mount', () => {
|
|
jest.clearAllMocks()
|
|
beforeEach(() => {
|
|
Wrapper = () => {
|
|
return mount(NotificationsPage, {
|
|
mocks,
|
|
localVue,
|
|
stubs,
|
|
})
|
|
}
|
|
wrapper = Wrapper()
|
|
wrapper.setData({
|
|
notifications: [
|
|
{
|
|
id: 'mentioned_in_comment/c4-1/u1',
|
|
read: false,
|
|
reason: 'mentioned_in_comment',
|
|
createdAt: '2023-03-06T14:32:47.924Z',
|
|
updatedAt: '2023-03-06T14:32:47.924Z',
|
|
},
|
|
{
|
|
id: 'mentioned_in_post/p8/u1',
|
|
read: false,
|
|
reason: 'mentioned_in_post',
|
|
createdAt: '2023-03-06T14:32:47.667Z',
|
|
updatedAt: '2023-03-06T14:32:47.667Z',
|
|
},
|
|
],
|
|
})
|
|
})
|
|
|
|
it('renders a Notications header', () => {
|
|
expect(wrapper.find('.ds-heading').exists()).toBe(true)
|
|
})
|
|
|
|
it('renders a `dropdown-filter` component', () => {
|
|
expect(wrapper.find('.dropdown-filter').exists()).toBe(true)
|
|
})
|
|
|
|
it('renders a `notifications-table` component', () => {
|
|
expect(wrapper.findComponent(NotificationsTable).exists()).toBe(true)
|
|
})
|
|
|
|
it('renders a `mark-all-as-read` button', () => {
|
|
expect(wrapper.find('[data-test="markAllAsRead-button"]').exists()).toBe(true)
|
|
})
|
|
|
|
describe('filter', () => {
|
|
it('has "All" as default', () => {
|
|
expect(wrapper.find('a.dropdown-filter').text()).toBe('notifications.filterLabel.all')
|
|
})
|
|
|
|
describe('select Read', () => {
|
|
beforeEach(() => {
|
|
wrapper.findComponent(DropdownFilter).vm.$emit('filter', wrapper.vm.filterOptions[1])
|
|
})
|
|
|
|
it('sets `notificationRead` to value of received option', () => {
|
|
expect(wrapper.vm.notificationRead).toEqual(wrapper.vm.filterOptions[1].value)
|
|
})
|
|
|
|
it('sets label to the label of the received option', () => {
|
|
expect(wrapper.vm.selected).toEqual(wrapper.vm.filterOptions[1].label)
|
|
})
|
|
|
|
it('refreshes the notifications', () => {
|
|
expect(mocks.$apollo.queries.notifications.refresh).toHaveBeenCalledTimes(1)
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('markNotificationAsRead', () => {
|
|
beforeEach(() => {
|
|
wrapper
|
|
.findComponent(NotificationsTable)
|
|
.vm.$emit('markNotificationAsRead', 'notificationSourceId')
|
|
})
|
|
|
|
it('calls markAllAsRead mutation', () => {
|
|
expect(mocks.$apollo.mutate).toHaveBeenCalledWith({
|
|
mutation: markAsReadMutation(),
|
|
variables: { id: 'notificationSourceId' },
|
|
})
|
|
})
|
|
|
|
describe('error handling', () => {
|
|
beforeEach(() => {
|
|
mocks.$apollo.mutate = jest.fn().mockRejectedValueOnce({ message: 'Some error message' })
|
|
wrapper
|
|
.findComponent(NotificationsTable)
|
|
.vm.$emit('markNotificationAsRead', 'notificationSourceId')
|
|
})
|
|
|
|
it('shows an error message if there is an error', () => {
|
|
expect(mocks.$toast.error).toHaveBeenCalledWith('Some error message')
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('markAllNotificationAsRead', () => {
|
|
it('calls markAllNotificationAsRead mutation and refreshes notification', async () => {
|
|
wrapper.find('button[data-test="markAllAsRead-button"]').trigger('click')
|
|
await expect(mocks.$apollo.mutate).toHaveBeenCalledWith({
|
|
mutation: markAllAsReadMutation(),
|
|
})
|
|
expect(mocks.$apollo.queries.notifications.refresh).toHaveBeenCalledTimes(1)
|
|
})
|
|
|
|
describe('error handling', () => {
|
|
it('shows an error message if there is an error', async () => {
|
|
mocks.$apollo.mutate = jest
|
|
.fn()
|
|
.mockRejectedValueOnce({ message: 'Another error message' })
|
|
await wrapper.find('button[data-test="markAllAsRead-button"]').trigger('click')
|
|
expect(mocks.$toast.error).toHaveBeenCalledWith('Another error message')
|
|
})
|
|
})
|
|
})
|
|
|
|
describe('PaginationButtons', () => {
|
|
beforeEach(() => {
|
|
wrapper = Wrapper()
|
|
})
|
|
|
|
describe('next: given a user is on the first page', () => {
|
|
it('adds offset to pageSize to skip first x notifications and display next page', () => {
|
|
wrapper.findComponent(PaginationButtons).vm.$emit('next')
|
|
expect(wrapper.vm.offset).toEqual(12)
|
|
})
|
|
})
|
|
|
|
describe('back: given a user is on the third page', () => {
|
|
it('sets offset when back is emitted', () => {
|
|
wrapper.setData({ offset: 24 })
|
|
wrapper.findComponent(PaginationButtons).vm.$emit('back')
|
|
expect(wrapper.vm.offset).toEqual(12)
|
|
})
|
|
})
|
|
})
|
|
})
|
|
})
|