aboutsummaryrefslogtreecommitdiffstats
path: root/frontend
diff options
context:
space:
mode:
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();
});
});