123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130 |
- // Copyright (C) 2012-2025 Zammad Foundation, https://zammad-foundation.org/
- import { renderComponent } from '#tests/support/components/index.ts'
- import {
- type ExtendedIMockSubscription,
- mockGraphQLApi,
- mockGraphQLSubscription,
- } from '#tests/support/mock-graphql-api.ts'
- import { useNotifications } from '#shared/components/CommonNotifications/index.ts'
- import { ApplicationBuildChecksumDocument } from '#shared/graphql/queries/applicationBuildChecksum.api.ts'
- import { AppMaintenanceDocument } from '#shared/graphql/subscriptions/appMaintenance.api.ts'
- import { EnumAppMaintenanceType } from '#shared/graphql/types.ts'
- import useAppMaintenanceCheck from '../useAppMaintenanceCheck.ts'
- let subscriptionAppMaintenance: ExtendedIMockSubscription
- describe('useAppMaintenanceCheck', () => {
- beforeAll(() => {
- mockGraphQLApi(ApplicationBuildChecksumDocument).willResolve({
- applicationBuildChecksum: {
- applicationBuildChecksum: 'initial-checksum',
- },
- })
- subscriptionAppMaintenance = mockGraphQLSubscription(AppMaintenanceDocument)
- renderComponent(
- {
- template: '<div>App Maintenance Check</div>',
- setup() {
- useAppMaintenanceCheck()
- },
- },
- {
- router: true,
- unmount: false,
- },
- )
- })
- afterEach(() => {
- useNotifications().clearAllNotifications()
- })
- it('reacts to config_updated message', async () => {
- await subscriptionAppMaintenance.next({
- data: {
- appMaintenance: {
- type: EnumAppMaintenanceType.ConfigChanged,
- },
- },
- })
- const { notifications } = useNotifications()
- expect(notifications.value[0].message).toBe(
- 'The configuration of Zammad has changed. Please reload at your earliest.',
- )
- })
- it('reacts to app_version message', async () => {
- await subscriptionAppMaintenance.next({
- data: {
- appMaintenance: {
- type: EnumAppMaintenanceType.AppVersion,
- },
- },
- })
- const { notifications } = useNotifications()
- expect(notifications.value[0].message).toBe(
- 'A newer version of the app is available. Please reload at your earliest.',
- )
- })
- it('reacts to reload_auto message', async () => {
- await subscriptionAppMaintenance.next({
- data: {
- appMaintenance: {
- type: EnumAppMaintenanceType.RestartAuto,
- },
- },
- })
- const { notifications } = useNotifications()
- expect(notifications.value[0].message).toBe(
- 'A newer version of the app is available. Please reload at your earliest.',
- )
- })
- it('reacts to reload_manual message', async () => {
- await subscriptionAppMaintenance.next({
- data: {
- appMaintenance: {
- type: EnumAppMaintenanceType.RestartManual,
- },
- },
- })
- const { notifications } = useNotifications()
- expect(notifications.value[0].message).toBe(
- 'A newer version of the app is available. Please reload at your earliest.',
- )
- })
- it('does not raise unhandled exceptions if the payload structure is wrong', async (context) => {
- context.skipConsole = true
- vi.spyOn(console, 'log').mockClear()
- await subscriptionAppMaintenance.next({
- data: {
- pushMessages: {
- title: null,
- text: null,
- },
- },
- })
- expect(console.log).not.toHaveBeenCalledWith(
- 'Uncaught Exception',
- new TypeError("Cannot read properties of undefined (reading 'type')"),
- )
- })
- })
|