File size: 1,191 Bytes
58973c7
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
import { render, screen, fireEvent } from '@testing-library/react';
import QuizGenerator from '../../components/QuizGenerator';

describe('QuizGenerator', () => {
  const mockOnProblemsGenerated = jest.fn();

  beforeEach(() => {
    global.fetch = jest.fn();
    mockOnProblemsGenerated.mockClear();
  });

  test('generates problems when button is clicked', async () => {
    const mockProblems = ['Problem 1', 'Problem 2'];
    const mockFetch = global.fetch as jest.Mock;
    mockFetch.mockResolvedValueOnce({
      ok: true,
      json: async () => ({ Problems: mockProblems }),
    });

    render(<QuizGenerator onProblemsGenerated={mockOnProblemsGenerated} />);
    
    const input = screen.getByLabelText('Quiz topic?');
    const button = screen.getByText('Generate');
    
    await fireEvent.change(input, { target: { value: 'React' } });
    await fireEvent.click(button);
    
    expect(mockFetch).toHaveBeenCalledWith('http://localhost:8000/problems/', {
      method: 'POST',
      headers: { 'Content-Type': 'application/json' },
      body: JSON.stringify({ user_query: 'React' }),
    });
    expect(mockOnProblemsGenerated).toHaveBeenCalledWith(mockProblems);
  });
});