feat: question tests
This commit is contained in:
		
							parent
							
								
									e8e2466b76
								
							
						
					
					
						commit
						da1d502ee6
					
				
					 2 changed files with 141 additions and 4 deletions
				
			
		|  | @ -54,10 +54,11 @@ export async function deleteQuestion(questionId: QuestionId): Promise<QuestionDT | ||||||
|     const questionRepository = getQuestionRepository(); |     const questionRepository = getQuestionRepository(); | ||||||
|     const question = await fetchQuestion(questionId); // throws error if not found
 |     const question = await fetchQuestion(questionId); // throws error if not found
 | ||||||
| 
 | 
 | ||||||
|     const loId: LearningObjectIdentifier = { |     const loId : LearningObjectIdentifier = { | ||||||
|         ...questionId.learningObjectIdentifier, |         hruid: questionId.learningObjectIdentifier.hruid, | ||||||
|         version: questionId.learningObjectIdentifier.version ?? FALLBACK_VERSION_NUM, |         language: questionId.learningObjectIdentifier.language, | ||||||
|     }; |         version: questionId.learningObjectIdentifier.version || FALLBACK_VERSION_NUM | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     await questionRepository.removeQuestionByLearningObjectAndSequenceNumber(loId, questionId.sequenceNumber); |     await questionRepository.removeQuestionByLearningObjectAndSequenceNumber(loId, questionId.sequenceNumber); | ||||||
|     return mapToQuestionDTO(question); |     return mapToQuestionDTO(question); | ||||||
|  |  | ||||||
							
								
								
									
										136
									
								
								backend/tests/controllers/questions.test.ts
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										136
									
								
								backend/tests/controllers/questions.test.ts
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,136 @@ | ||||||
|  | import {beforeAll, beforeEach, describe, expect, it, Mock, vi} from "vitest"; | ||||||
|  | import {Request, Response} from "express"; | ||||||
|  | import {setupTestApp} from "../setup-tests"; | ||||||
|  | import { | ||||||
|  |     getAllQuestionsHandler, | ||||||
|  |     getQuestionHandler, updateQuestionHandler | ||||||
|  | } from "../../src/controllers/questions"; | ||||||
|  | import {Language} from "@dwengo-1/common/util/language"; | ||||||
|  | import {NotFoundException} from "../../src/exceptions/not-found-exception"; | ||||||
|  | import {BadRequestException} from "../../src/exceptions/bad-request-exception"; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | describe('Questions controllers', () => { | ||||||
|  |     let req: Partial<Request>; | ||||||
|  |     let res: Partial<Response>; | ||||||
|  | 
 | ||||||
|  |     let jsonMock: Mock; | ||||||
|  | 
 | ||||||
|  |     beforeAll(async () => { | ||||||
|  |         await setupTestApp(); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     beforeEach(() => { | ||||||
|  |         jsonMock = vi.fn(); | ||||||
|  |         res = { | ||||||
|  |             json: jsonMock, | ||||||
|  |         }; | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('Get question list', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05', version: '1' }, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await getAllQuestionsHandler(req as Request, res as Response); | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ questions: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         const result = jsonMock.mock.lastCall?.[0]; | ||||||
|  |         // console.log(result.questions);
 | ||||||
|  |         expect(result.questions).to.have.length.greaterThan(1); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     it('Get question', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05', version: '1', seq: '1'}, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await getQuestionHandler(req as Request, res as Response); | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ question: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         // const result = jsonMock.mock.lastCall?.[0];
 | ||||||
|  |         // console.log(result.question);
 | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     it('Get question with fallback sequence number and version', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05'}, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await getQuestionHandler(req as Request, res as Response); | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ question: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         // const result = jsonMock.mock.lastCall?.[0];
 | ||||||
|  |         // console.log(result.question);
 | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     it('Get question with fallback sequence number and version', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05'}, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await getQuestionHandler(req as Request, res as Response); | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ question: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         // const result = jsonMock.mock.lastCall?.[0];
 | ||||||
|  |         // console.log(result.question);
 | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     it('Get question hruid does not exist', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id_not_exist'}, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await expect( async () => getQuestionHandler(req as Request, res as Response)) | ||||||
|  |             .rejects.toThrow(NotFoundException); | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     it('Get question no hruid given', async () => { | ||||||
|  |         req = { | ||||||
|  |             params: {}, | ||||||
|  |             query: { lang: Language.English, full: 'true' }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await expect( async () => getQuestionHandler(req as Request, res as Response)) | ||||||
|  |             .rejects.toThrow(BadRequestException); | ||||||
|  |     }) | ||||||
|  | 
 | ||||||
|  |     /* | ||||||
|  |     it('Create and delete question', async() => { | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05', version: '1', seq: '2'}, | ||||||
|  |             query: { lang: Language.English }, | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await deleteQuestionHandler(req as Request, res as Response); | ||||||
|  | 
 | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ question: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         const result = jsonMock.mock.lastCall?.[0]; | ||||||
|  |         console.log(result.question); | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |      */ | ||||||
|  | 
 | ||||||
|  |     it('Update question', async() => { | ||||||
|  |         const newContent = "updated question"; | ||||||
|  |         req = { | ||||||
|  |             params: { hruid: 'id05', version: '1', seq: '1'}, | ||||||
|  |             query: { lang: Language.English }, | ||||||
|  |             body: { content: newContent } | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         await updateQuestionHandler(req as Request, res as Response); | ||||||
|  | 
 | ||||||
|  |         expect(jsonMock).toHaveBeenCalledWith(expect.objectContaining({ question: expect.anything() })); | ||||||
|  | 
 | ||||||
|  |         const result = jsonMock.mock.lastCall?.[0]; | ||||||
|  |         // console.log(result.question);
 | ||||||
|  |         expect(result.question.content).to.eq(newContent); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
		Reference in a new issue
	
	 Gabriellvl
						Gabriellvl