veza/apps/web/src/components/ui/AnimatedNumber.test.tsx
senke 34e9d69af3 fix(tests): add missing component tests and fix failing tests
- Fix setTimeout memory leak in ChatRoom.tsx by storing timeout in
  useRef and cleaning up on unmount
- Add tests for Accordion, Collapsible, FloatingInput, AnimatedNumber,
  and FAB components (5 new test files, all passing)
- Fix socialService methods (deleteComment, markRead, markAllRead) to
  return values matching test expectations
- Fix MSW handlers for chat/token and notification endpoints to use
  proper { success: true, data: ... } envelope format
- Fix invalid CSS selector in TrackList.test.tsx that caused JSDOM crash
- Document excluded test files with TODO tickets in vitest.config.ts

Co-authored-by: Cursor <cursoragent@cursor.com>
2026-02-12 22:59:09 +01:00

39 lines
1.3 KiB
TypeScript

import { describe, it, expect, vi } from 'vitest';
import { render, screen } from '@testing-library/react';
// Mock the animated counter hook to return the end value immediately
vi.mock('@/hooks/useAnimatedCounter', () => ({
useAnimatedCounter: ({ end }: { end: number }) => end,
}));
import { AnimatedNumber } from './AnimatedNumber';
describe('AnimatedNumber', () => {
it('renders the value', () => {
render(<AnimatedNumber value={42} />);
expect(screen.getByText('42')).toBeInTheDocument();
});
it('applies custom className', () => {
const { container } = render(
<AnimatedNumber value={100} className="text-lg" />
);
const span = container.querySelector('span');
expect(span?.className).toContain('text-lg');
expect(span?.className).toContain('tabular-nums');
});
it('uses format function when provided', () => {
render(
<AnimatedNumber value={1500} format={(n) => `$${n}`} />
);
expect(screen.getByText('$1500')).toBeInTheDocument();
});
it('formats large numbers with locale string', () => {
render(<AnimatedNumber value={1000} />);
// toLocaleString will format 1000 — the exact output depends on locale
const span = screen.getByText((content) => content.includes('1'));
expect(span).toBeInTheDocument();
});
});