// Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/ import { axe } from 'vitest-axe' import { visitView } from '#tests/support/components/visitView.ts' import { mockGraphQLApi, mockGraphQLSubscription, } from '#tests/support/mock-graphql-api.ts' import { mockTicketOverviews } from '#tests/support/mocks/ticket-overviews.ts' import { waitUntil, waitUntilApisResolved } from '#tests/support/utils.ts' import { OrganizationDocument } from '#shared/entities/organization/graphql/queries/organization.api.ts' import { OrganizationUpdatesDocument } from '#shared/entities/organization/graphql/subscriptions/organizationUpdates.api.ts' import { defaultOrganization, mockOrganizationObjectAttributes, } from '#mobile/entities/organization/__tests__/mocks/organization-mocks.ts' import { defaultUser, mockUserDetailsApis, } from '#mobile/entities/user/__tests__/mocks/user-mocks.ts' import { mockTicketDetailViewGql } from './mocks/detail-view.ts' import { mockTicketsByOverview } from './mocks/overview.ts' describe('testing ticket a11y', () => { beforeEach(() => { mockTicketOverviews() }) test('ticket overview has no accessibility violations', async () => { mockTicketsByOverview([]) await visitView('/tickets/view') const results = await axe(document.body) expect(results).toHaveNoViolations() }) test('ticket detail view has no accessibility violations', async () => { const { waitUntilTicketLoaded } = mockTicketDetailViewGql() const view = await visitView('/tickets/1') expect(view.getByTestId('loader-list')).toBeInTheDocument() expect(view.getByTestId('loader-title')).toBeInTheDocument() expect(view.getByTestId('loader-header')).toBeInTheDocument() await waitUntilTicketLoaded() const results = await axe(document.body) expect(results).toHaveNoViolations() }) test('ticket organization information has no accessibility violations', async () => { mockTicketDetailViewGql() const mockApi = mockGraphQLApi(OrganizationDocument).willResolve({ organization: defaultOrganization(), }) mockGraphQLSubscription(OrganizationUpdatesDocument) const mockAttributes = mockOrganizationObjectAttributes() await visitView('/tickets/1/information/organization') await waitUntil(() => mockApi.calls.resolve && mockAttributes.calls.resolve) const results = await axe(document.body) expect(results).toHaveNoViolations() }) test('ticket user information has no accessibility violations', async () => { mockTicketDetailViewGql() const { mockUser, mockAttributes } = mockUserDetailsApis(defaultUser(), { skipMockOnlineNotificationSeen: true, }) await visitView('/tickets/1/information/customer') await waitUntilApisResolved(mockUser, mockAttributes) const results = await axe(document.body) expect(results).toHaveNoViolations() }) })