aboutsummaryrefslogtreecommitdiffstats
path: root/frontend
diff options
context:
space:
mode:
authorAdam Mathes <adam@adammathes.com>2026-02-13 19:19:16 -0800
committerAdam Mathes <adam@adammathes.com>2026-02-13 19:19:16 -0800
commit15e6bf85964110dd27bf09291c5971a62119e242 (patch)
treea38fdc7bc80c731184f711a626223f34343971ca /frontend
parentea39f5aac74621861f6d88f98f0e0ca2eaad82f8 (diff)
downloadneko-15e6bf85964110dd27bf09291c5971a62119e242.tar.gz
neko-15e6bf85964110dd27bf09291c5971a62119e242.tar.bz2
neko-15e6bf85964110dd27bf09291c5971a62119e242.zip
test: fix FeedList tests for collapsible state
Diffstat (limited to 'frontend')
-rw-r--r--frontend/src/components/FeedList.test.tsx28
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();
});
});