From 1aba1d609831a1ee0413c4b65f57c0aa67c3239d Mon Sep 17 00:00:00 2001
From: JubaAzul <118773284+JubaAzul@users.noreply.github.com>
Date: Tue, 4 Feb 2025 23:14:10 -0500
Subject: [PATCH] =?UTF-8?q?Indiquer=20le=20num=C3=A9ro=20de=20la=20questio?=
=?UTF-8?q?n=20dans=20l'affichage=20enseignant=20Fixes=20#207?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
.../pages/ManageRoom/ManageRoom.test.tsx | 253 ++++++++++++++++++
.../LaunchQuizDialog/LaunchQuizDialog.tsx | 4 +-
2 files changed, 255 insertions(+), 2 deletions(-)
create mode 100644 client/src/__tests__/pages/ManageRoom/ManageRoom.test.tsx
diff --git a/client/src/__tests__/pages/ManageRoom/ManageRoom.test.tsx b/client/src/__tests__/pages/ManageRoom/ManageRoom.test.tsx
new file mode 100644
index 0000000..684f92e
--- /dev/null
+++ b/client/src/__tests__/pages/ManageRoom/ManageRoom.test.tsx
@@ -0,0 +1,253 @@
+import React from 'react';
+import { render, screen, fireEvent, waitFor, act } from '@testing-library/react';
+import '@testing-library/jest-dom';
+import { MemoryRouter, useNavigate, useParams } from 'react-router-dom';
+import ManageRoom from 'src/pages/Teacher/ManageRoom/ManageRoom';
+import { StudentType } from 'src/Types/StudentType';
+import { QuizType } from 'src/Types/QuizType';
+import webSocketService, { AnswerReceptionFromBackendType } from 'src/services/WebsocketService';
+import ApiService from 'src/services/ApiService';
+import { Socket } from 'socket.io-client';
+
+jest.mock('src/services/WebsocketService');
+jest.mock('src/services/ApiService');
+jest.mock('react-router-dom', () => ({
+ ...jest.requireActual('react-router-dom'),
+ useNavigate: jest.fn(),
+ useParams: jest.fn(),
+}));
+
+const mockSocket = {
+ on: jest.fn(),
+ off: jest.fn(),
+ emit: jest.fn(),
+ connect: jest.fn(),
+ disconnect: jest.fn(),
+} as unknown as Socket;
+
+const mockQuiz: QuizType = {
+ _id: 'test-quiz-id',
+ title: 'Test Quiz',
+ content: ['::Q1:: Question 1 { =Answer1 ~Answer2 }', '::Q2:: Question 2 { =Answer1 ~Answer2 }'],
+ folderId: 'folder-id',
+ folderName: 'folder-name',
+ userId: 'user-id',
+ created_at: new Date(),
+ updated_at: new Date()
+};
+
+const mockStudents: StudentType[] = [
+ { id: '1', name: 'Student 1', answers: [] },
+ { id: '2', name: 'Student 2', answers: [] },
+];
+
+const mockAnswerData: AnswerReceptionFromBackendType = {
+ answer: 'Answer1',
+ idQuestion: 1,
+ idUser: '1',
+ username: 'Student 1',
+};
+
+describe('ManageRoom', () => {
+ const navigate = jest.fn();
+ const useParamsMock = useParams as jest.Mock;
+
+ beforeEach(() => {
+ jest.clearAllMocks();
+ (useNavigate as jest.Mock).mockReturnValue(navigate);
+ useParamsMock.mockReturnValue({ id: 'test-quiz-id' });
+ (ApiService.getQuiz as jest.Mock).mockResolvedValue(mockQuiz);
+ (webSocketService.connect as jest.Mock).mockReturnValue(mockSocket);
+ });
+
+ test('prepares to launch quiz and fetches quiz data', async () => {
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ await waitFor(() => {
+ expect(ApiService.getQuiz).toHaveBeenCalledWith('test-quiz-id');
+ });
+
+ const launchButton = screen.getByText('Lancer');
+ fireEvent.click(launchButton);
+
+ const rythmeButton = screen.getByText('Rythme du professeur');
+ fireEvent.click(rythmeButton);
+
+ const secondLaunchButton = screen.getAllByText('Lancer');
+ fireEvent.click(secondLaunchButton[1]);
+
+ await waitFor(() => {
+ expect(screen.getByText('Test Quiz')).toBeInTheDocument();
+ expect(screen.getByText('Salle: test-room-name')).toBeInTheDocument();
+ expect(screen.getByText('0/60')).toBeInTheDocument();
+ expect(screen.getByText('Question 1/2')).toBeInTheDocument();
+ });
+ });
+
+ test('handles create-success event', async () => {
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ await waitFor(() => {
+ expect(screen.getByText('Salle: test-room-name')).toBeInTheDocument();
+ });
+ });
+
+ test('handles user-joined event', async () => {
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ await act(async () => {
+ const userJoinedCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'user-joined')[1];
+ userJoinedCallback(mockStudents[0]);
+ });
+
+ await waitFor(() => {
+ expect(screen.getByText('Student 1')).toBeInTheDocument();
+
+ });
+
+ const launchButton = screen.getByText('Lancer');
+ fireEvent.click(launchButton);
+
+ const rythmeButton = screen.getByText('Rythme du professeur');
+ fireEvent.click(rythmeButton);
+
+ const secondLaunchButton = screen.getAllByText('Lancer');
+ fireEvent.click(secondLaunchButton[1]);
+
+ await waitFor(() => {
+ expect(screen.getByText('1/60')).toBeInTheDocument();
+
+ });
+ });
+
+ test('handles submit-answer-room event', async () => {
+ const consoleSpy = jest.spyOn(console, 'log');
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ const launchButton = screen.getByText('Lancer');
+ fireEvent.click(launchButton);
+
+ const rythmeButton = screen.getByText('Rythme du professeur');
+ fireEvent.click(rythmeButton);
+
+ const secondLaunchButton = screen.getAllByText('Lancer');
+ fireEvent.click(secondLaunchButton[1]);
+
+ await act(async () => {
+ const userJoinedCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'user-joined')[1];
+ userJoinedCallback(mockStudents[0]);
+ });
+
+ await act(async () => {
+ const submitAnswerCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'submit-answer-room')[1];
+ submitAnswerCallback(mockAnswerData);
+ });
+
+ await waitFor(() => {
+ expect(consoleSpy).toHaveBeenCalledWith('Received answer from Student 1 for question 1: Answer1');
+ });
+
+ consoleSpy.mockRestore();
+ });
+
+ test('handles next question', async () => {
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ const launchButton = screen.getByText('Lancer');
+ fireEvent.click(launchButton);
+
+ const rythmeButton = screen.getByText('Rythme du professeur');
+ fireEvent.click(rythmeButton);
+
+ const secondLaunchButton = screen.getAllByText('Lancer');
+ fireEvent.click(secondLaunchButton[1]);
+
+ const nextQuestionButton = screen.getByText('Prochaine question');
+ fireEvent.click(nextQuestionButton);
+
+ await waitFor(() => {
+ expect(screen.getByText('Question 2/2')).toBeInTheDocument();
+ });
+ });
+
+ test('handles disconnect', async () => {
+ await act(async () => {
+ render(
+
+
+
+ );
+ });
+
+ await act(async () => {
+ const createSuccessCallback = (mockSocket.on as jest.Mock).mock.calls.find(call => call[0] === 'create-success')[1];
+ createSuccessCallback('test-room-name');
+ });
+
+ const disconnectButton = screen.getByText('Quitter');
+ fireEvent.click(disconnectButton);
+
+ const confirmButton = screen.getAllByText('Confirmer');
+ fireEvent.click(confirmButton[1]);
+
+ await waitFor(() => {
+ expect(webSocketService.disconnect).toHaveBeenCalled();
+ expect(navigate).toHaveBeenCalledWith('/teacher/dashboard');
+ });
+ });
+});
\ No newline at end of file
diff --git a/client/src/components/LaunchQuizDialog/LaunchQuizDialog.tsx b/client/src/components/LaunchQuizDialog/LaunchQuizDialog.tsx
index 3bd307b..3aaf401 100644
--- a/client/src/components/LaunchQuizDialog/LaunchQuizDialog.tsx
+++ b/client/src/components/LaunchQuizDialog/LaunchQuizDialog.tsx
@@ -47,10 +47,10 @@ const LaunchQuizDialog: React.FC = ({ open, handleOnClose, launchQuiz, se