import { describe, it, expect } from 'vitest';
import { render, screen } from '@testing-library/react';
import { StatsPanel } from '../components/StatsPanel';
import type { PeriodStats } from '../services/DataService';
const mockStats: PeriodStats = {
totalVolume: 1234.56,
transactionCount: 42,
topCities: [
{ name: 'Paris', volume: 700, count: 20 },
{ name: 'Lyon', volume: 400, count: 15 },
{ name: 'Bordeaux', volume: 134, count: 7 },
],
};
describe('StatsPanel', () => {
it('shows loading skeletons when loading=true', () => {
const { container } = render(
);
const skeletons = container.querySelectorAll('.animate-pulse');
expect(skeletons.length).toBeGreaterThan(0);
});
it('displays the total volume when stats are available', () => {
render();
expect(screen.getByText(/1\s*234/)).toBeInTheDocument();
});
it('displays the transaction count', () => {
render();
expect(screen.getByText('42')).toBeInTheDocument();
});
it('renders exactly 3 top cities in correct order', () => {
render();
const cities = ['Paris', 'Lyon', 'Bordeaux'];
cities.forEach((city) => expect(screen.getByText(city)).toBeInTheDocument());
});
it('shows "24 dernières heures" for periodDays=1', () => {
render();
expect(screen.getByText(/24 dernières heures/i)).toBeInTheDocument();
});
it('shows "30 derniers jours" for periodDays=30', () => {
render();
expect(screen.getByText(/30 derniers jours/i)).toBeInTheDocument();
});
it('does not crash with an empty topCities list', () => {
const emptyStats = { ...mockStats, topCities: [] };
expect(() =>
render()
).not.toThrow();
});
});