123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { visitView } from '#tests/support/components/visitView.ts'
- import { mockApplicationConfig } from '#tests/support/mock-applicationConfig.ts'
- import { mockUserCurrent } from '#tests/support/mock-userCurrent.ts'
- import { waitForNextTick } from '#tests/support/utils.ts'
- import { EnumAuthenticationProvider } from '#shared/graphql/types.ts'
- import { convertToGraphQLId } from '#shared/graphql/utils.ts'
- import { waitForUserCurrentRemoveLinkedAccountMutationCalls } from '#desktop/pages/personal-setting/graphql/mutations/userCurrentLinkedAccount.mocks.ts'
- describe('linked accounts page', () => {
- it('is not accessible if no providers are enabled', async () => {
- const view = await visitView('/personal-setting/linked-accounts')
- await vi.waitFor(() => {
- expect(view, 'correctly redirects to error page').toHaveCurrentUrl(
- '/error',
- )
- })
- })
- describe('with enabled providers', () => {
- beforeEach(() => {
- mockApplicationConfig({
- auth_facebook: true,
- auth_github: true,
- })
- mockUserCurrent({
- lastname: 'Doe',
- firstname: 'John',
- fullname: 'John Doe',
- id: convertToGraphQLId('User', 4),
- authorizations: [
- {
- __typename: 'Authorization',
- id: convertToGraphQLId('Authorization', 1),
- provider: EnumAuthenticationProvider.Github,
- uid: '85683661',
- username: 'foobar',
- },
- ],
- })
- })
- it('renders a list of authorization providers', async () => {
- const view = await visitView('/personal-setting/linked-accounts')
- expect(view.getByText('GitHub')).toBeInTheDocument() // application
- expect(view.getByText('foobar')).toBeInTheDocument() // username for GitHub
- expect(view.getByText('Facebook')).toBeInTheDocument() // application
- expect(view.getAllByIconName('plus-square-fill')).toHaveLength(1)
- expect(view.getAllByIconName('trash3')).toHaveLength(1)
- })
- it('links a new authorization provider', async (context) => {
- context.skipConsole = true
- const view = await visitView('/personal-setting/linked-accounts')
- expect(
- view.queryByLabelText('Link account on GitHub'),
- ).not.toBeInTheDocument()
- expect(view.getByLabelText('Remove account link on GitHub'))
- expect(
- view.queryByLabelText('Link account on Facebook'),
- ).toBeInTheDocument()
- await view.events.click(view.getByLabelText('Link account on Facebook'))
- })
- it('removes an authorization provider', async () => {
- const view = await visitView('/personal-setting/linked-accounts')
- await view.events.click(
- view.getByLabelText('Remove account link on GitHub'),
- )
- expect(
- await view.findByRole('dialog', { name: 'Delete Object' }),
- ).toBeInTheDocument()
- expect(
- view.getByText('Are you sure you want to delete this object?'),
- ).toBeInTheDocument()
- await view.events.click(
- view.getByRole('button', { name: 'Delete Object' }),
- )
- const mockCalls =
- await waitForUserCurrentRemoveLinkedAccountMutationCalls()
- expect(mockCalls[0].variables).toEqual({
- provider: EnumAuthenticationProvider.Github,
- uid: '85683661',
- })
- mockUserCurrent({
- lastname: 'Doe',
- firstname: 'John',
- fullname: 'John Doe',
- id: convertToGraphQLId('User', 4),
- authorizations: [],
- })
- await waitForNextTick()
- expect(view.queryByIconName('trash3')).not.toBeInTheDocument()
- expect(view.getAllByIconName('plus-square-fill')).toHaveLength(2)
- })
- })
- })
|