Files
lcbp3/frontend/components/admin/ai/__tests__/VersionHistory.test.tsx
T
admin 037fbb65f5
CI / CD Pipeline / build (push) Successful in 7m34s
CI / CD Pipeline / deploy (push) Successful in 20m3s
690617:1649 237 #01.4
2026-06-17 16:49:28 +07:00

111 lines
3.4 KiB
TypeScript

// File: frontend/components/admin/ai/__tests__/VersionHistory.test.tsx
import React from 'react';
import { render, screen, waitFor } from '@testing-library/react';
import userEvent from '@testing-library/user-event';
import { describe, it, expect, vi, beforeEach } from 'vitest';
import VersionHistory from '../VersionHistory';
vi.mock('react-i18next', () => ({
useTranslation: () => ({
t: (key: string) => key,
}),
}));
describe('VersionHistory', () => {
const mockOnLoadTemplate = vi.fn();
const mockOnActivateVersion = vi.fn();
const mockOnDeleteVersion = vi.fn();
beforeEach(() => {
vi.clearAllMocks();
});
const generateVersions = (count: number) => {
return Array.from({ length: count }, (_, i) => ({
versionNumber: i + 1,
promptType: 'ocr_extraction',
promptText: 'prompt text',
createdAt: new Date().toISOString(),
isActive: i === 0,
manualNote: `Note ${i + 1}`,
authorName: 'Admin',
}));
};
it('renders loading state', () => {
render(
<VersionHistory
versions={[]}
isLoading={true}
onLoadTemplate={mockOnLoadTemplate}
onActivateVersion={mockOnActivateVersion}
onDeleteVersion={mockOnDeleteVersion}
isActivating={false}
isDeleting={false}
/>
);
expect(screen.getByText(/prompt_management.version_history/i)).toBeInTheDocument();
});
it('renders empty state', () => {
render(
<VersionHistory
versions={[]}
isLoading={false}
onLoadTemplate={mockOnLoadTemplate}
onActivateVersion={mockOnActivateVersion}
onDeleteVersion={mockOnDeleteVersion}
isActivating={false}
isDeleting={false}
/>
);
expect(screen.getByText('prompt_management.no_versions')).toBeInTheDocument();
});
it('renders versions', () => {
const versions = generateVersions(2);
render(
<VersionHistory
versions={versions}
isLoading={false}
onLoadTemplate={mockOnLoadTemplate}
onActivateVersion={mockOnActivateVersion}
onDeleteVersion={mockOnDeleteVersion}
isActivating={false}
isDeleting={false}
/>
);
expect(screen.getByText('v1')).toBeInTheDocument();
expect(screen.getByText('v2')).toBeInTheDocument();
expect(screen.getByText('Note 1')).toBeInTheDocument();
expect(screen.getByText('prompt_management.is_active')).toBeInTheDocument();
});
it('handles pagination', async () => {
const versions = generateVersions(25); // Page size is 20
render(
<VersionHistory
versions={versions}
isLoading={false}
onLoadTemplate={mockOnLoadTemplate}
onActivateVersion={mockOnActivateVersion}
onDeleteVersion={mockOnDeleteVersion}
isActivating={false}
isDeleting={false}
/>
);
// Infinite scroll: initial render shows first PAGE_SIZE (20) items
expect(screen.getByText('v1')).toBeInTheDocument();
expect(screen.getByText('v20')).toBeInTheDocument();
// Items beyond PAGE_SIZE are not yet rendered (IntersectionObserver not triggered in jsdom)
expect(screen.queryByText('v21')).not.toBeInTheDocument();
expect(screen.queryByText('v25')).not.toBeInTheDocument();
// "Load more" indicator is shown when there are hidden items
expect(screen.getByText(/แสดง 20 จาก 25 เวอร์ชัน/)).toBeInTheDocument();
});
});