Files
privacy.sexy/tests/unit/presentation/components/Shared/Hooks/UseScriptDiagnosticsCollector.spec.ts
undergroundwires a721e82a4f Bump TypeScript to 5.3 with verbatimModuleSyntax
This commit upgrades TypeScript to the latest version 5.3 and introduces
`verbatimModuleSyntax` in line with the official Vue guide
recommendatinos (vuejs/docs#2592).

By enforcing `import type` for type-only imports, this commit improves
code clarity and supports tooling optimization, ensuring imports are
only bundled when necessary for runtime.

Changes:

- Bump TypeScript to 5.3.3 across the project.
- Adjust import statements to utilize `import type` where applicable,
  promoting cleaner and more efficient code.
2024-02-27 04:20:22 +01:00

28 lines
1.2 KiB
TypeScript

import { describe, it, expect } from 'vitest';
import { useScriptDiagnosticsCollector } from '@/presentation/components/Shared/Hooks/UseScriptDiagnosticsCollector';
import { ScriptDiagnosticsCollectorStub } from '@tests/unit/shared/Stubs/ScriptDiagnosticsCollectorStub';
import type { WindowVariables } from '@/infrastructure/WindowVariables/WindowVariables';
describe('useScriptDiagnosticsCollector', () => {
it('returns undefined if collector is not present on the window object', () => {
// arrange
const emptyWindow = {} as WindowVariables;
// act
const { scriptDiagnosticsCollector } = useScriptDiagnosticsCollector(emptyWindow);
// assert
expect(scriptDiagnosticsCollector).to.equal(undefined);
});
it('returns the scriptDiagnosticsCollector when it is present on the window object', () => {
// arrange
const expectedCollector = new ScriptDiagnosticsCollectorStub();
const windowWithVariable: Partial<WindowVariables> = {
scriptDiagnosticsCollector: expectedCollector,
} as Partial<WindowVariables>;
// act
const { scriptDiagnosticsCollector } = useScriptDiagnosticsCollector(windowWithVariable);
// assert
expect(scriptDiagnosticsCollector).to.equal(expectedCollector);
});
});