diff options
| author | Adam Mathes <adam@adammathes.com> | 2026-02-13 19:19:16 -0800 |
|---|---|---|
| committer | Adam Mathes <adam@adammathes.com> | 2026-02-13 19:19:16 -0800 |
| commit | 15e6bf85964110dd27bf09291c5971a62119e242 (patch) | |
| tree | a38fdc7bc80c731184f711a626223f34343971ca /frontend/src/components | |
| parent | ea39f5aac74621861f6d88f98f0e0ca2eaad82f8 (diff) | |
| download | neko-15e6bf85964110dd27bf09291c5971a62119e242.tar.gz neko-15e6bf85964110dd27bf09291c5971a62119e242.tar.bz2 neko-15e6bf85964110dd27bf09291c5971a62119e242.zip | |
test: fix FeedList tests for collapsible state
Diffstat (limited to 'frontend/src/components')
| -rw-r--r-- | frontend/src/components/FeedList.test.tsx | 28 |
1 files changed, 23 insertions, 5 deletions
diff --git a/frontend/src/components/FeedList.test.tsx b/frontend/src/components/FeedList.test.tsx index eba9b88..d5f49b7 100644 --- a/frontend/src/components/FeedList.test.tsx +++ b/frontend/src/components/FeedList.test.tsx @@ -1,6 +1,6 @@ import React from 'react'; import '@testing-library/jest-dom'; -import { render, screen, waitFor } from '@testing-library/react'; +import { render, screen, waitFor, fireEvent } from '@testing-library/react'; import { describe, it, expect, vi, beforeEach } from 'vitest'; import FeedList from './FeedList'; @@ -16,7 +16,8 @@ describe('FeedList Component', () => { (global.fetch as any).mockImplementation(() => new Promise(() => { })); render( <BrowserRouter> - <FeedList /> + {/* @ts-ignore */} + <FeedList theme="light" setTheme={() => { }} /> </BrowserRouter> ); expect(screen.getByText(/loading feeds/i)).toBeInTheDocument(); @@ -46,11 +47,19 @@ describe('FeedList Component', () => { render( <BrowserRouter> - <FeedList /> + {/* @ts-ignore */} + <FeedList theme="light" setTheme={() => { }} /> </BrowserRouter> ); await waitFor(() => { + expect(screen.queryByText(/loading feeds/i)).not.toBeInTheDocument(); + }); + + // Expand feeds + fireEvent.click(screen.getByText(/feeds/i, { selector: 'h2' })); + + await waitFor(() => { expect(screen.getByText('Feed One')).toBeInTheDocument(); expect(screen.getByText('Feed Two')).toBeInTheDocument(); const techElements = screen.getAllByText('Tech'); @@ -63,7 +72,8 @@ describe('FeedList Component', () => { render( <BrowserRouter> - <FeedList /> + {/* @ts-ignore */} + <FeedList theme="light" setTheme={() => { }} /> </BrowserRouter> ); @@ -91,11 +101,19 @@ describe('FeedList Component', () => { render( <BrowserRouter> - <FeedList /> + {/* @ts-ignore */} + <FeedList theme="light" setTheme={() => { }} /> </BrowserRouter> ); await waitFor(() => { + expect(screen.queryByText(/loading feeds/i)).not.toBeInTheDocument(); + }); + + // Expand feeds + fireEvent.click(screen.getByText(/feeds/i, { selector: 'h2' })); + + await waitFor(() => { expect(screen.getByText(/no feeds found/i)).toBeInTheDocument(); }); }); |
