test: alle functies in learningPaths.ts zijn getest en de testen slagen
This commit is contained in:
		
							parent
							
								
									2a7be32705
								
							
						
					
					
						commit
						fca8e7ff7a
					
				
					 1 changed files with 51 additions and 5 deletions
				
			
		|  | @ -1,32 +1,78 @@ | |||
| import { describe, it, expect, vi } from 'vitest'; | ||||
| import { fetchLearningPaths } from '../../src/services/learningPaths'; | ||||
| import { fetchLearningPaths, searchLearningPaths } from '../../src/services/learningPaths'; | ||||
| import { fetchWithLogging } from '../../src/util/apiHelper'; | ||||
| import { LearningPathResponse } from '../../src/interfaces/learningPath'; | ||||
| 
 | ||||
| // Function to mock the fetchWithLogging module using vi
 | ||||
| vi.mock('../../src/util/apiHelper', () => ({ | ||||
|     fetchWithLogging: vi.fn(), | ||||
| })); | ||||
| 
 | ||||
| describe('fetchLearningPaths', () => { | ||||
|     const mockHruids = ['pn_werking', 'art1']; | ||||
|     const language = 'en'; | ||||
|     const source = 'Test Source'; | ||||
|     const mockResponse = [{ title: 'Test Path', hruids: mockHruids }]; | ||||
| 
 | ||||
|     it('✅ Moet een succesvolle response retourneren wanneer hruids zijn opgegeven', async () => { | ||||
|     it('✅ Should return a successful response when HRUIDs are provided', async () => { | ||||
|         // Mock response van fetchWithLogging
 | ||||
|         //const mockResponse = [{ title: 'Test Path', hruids: mockHruids }];
 | ||||
|         const mockResponse = [{ title: 'Test Path', hruids: mockHruids }]; | ||||
| 
 | ||||
|         // Mock the function to return mockResponse
 | ||||
|         vi.mocked(fetchWithLogging).mockResolvedValue(mockResponse); | ||||
| 
 | ||||
|         const result: LearningPathResponse = await fetchLearningPaths(mockHruids, language, source); | ||||
| 
 | ||||
|         expect(result.success).toBe(true); | ||||
|         //expect(result.data).toEqual(mockResponse);
 | ||||
|         expect(result.data).toEqual(mockResponse); | ||||
|         expect(result.source).toBe(source); | ||||
|     }); | ||||
| 
 | ||||
|     it('⚠️ Moet een foutmelding teruggeven als er geen hruids zijn opgegeven', async () => { | ||||
|     it('⚠️ Should return an error when no HRUIDs are provided', async () => { | ||||
|         const result: LearningPathResponse = await fetchLearningPaths([], language, source); | ||||
| 
 | ||||
|         vi.mocked(fetchWithLogging).mockResolvedValue(mockResponse); | ||||
| 
 | ||||
|         expect(result.success).toBe(false); | ||||
|         expect(result.data).toBeNull(); | ||||
|         expect(result.message).toBe(`No HRUIDs provided for ${source}.`); | ||||
|     }); | ||||
| 
 | ||||
|     it('⚠️ Should return a failure response when no learning paths are found', async () => { | ||||
|         // Mock fetchWithLogging to return an empty array
 | ||||
|         vi.mocked(fetchWithLogging).mockResolvedValue([]); | ||||
| 
 | ||||
|         const result: LearningPathResponse = await fetchLearningPaths(mockHruids, language, source); | ||||
| 
 | ||||
|         expect(result.success).toBe(false); | ||||
|         expect(result.data).toEqual([]); | ||||
|         expect(result.message).toBe(`No learning paths found for ${source}.`); | ||||
|     }); | ||||
| }); | ||||
| 
 | ||||
| describe('searchLearningPaths', () => { | ||||
|     const query = 'robotics'; | ||||
|     const language = 'en'; | ||||
| 
 | ||||
|     it('✅ Should return search results when API responds with data', async () => { | ||||
|         const mockResults = [ | ||||
|             { title: 'Robotics Basics', hruids: ['robotics_101'] }, | ||||
|             { title: 'Advanced Robotics', hruids: ['robotics_advanced'] }, | ||||
|         ]; | ||||
| 
 | ||||
|         // Mock fetchWithLogging to return search results
 | ||||
|         vi.mocked(fetchWithLogging).mockResolvedValue(mockResults); | ||||
| 
 | ||||
|         const result = await searchLearningPaths(query, language); | ||||
| 
 | ||||
|         expect(result).toEqual(mockResults); | ||||
|     }); | ||||
| 
 | ||||
|     it('⚠️ Should return an empty array when API returns no results', async () => { | ||||
|         vi.mocked(fetchWithLogging).mockResolvedValue([]); | ||||
| 
 | ||||
|         const result = await searchLearningPaths(query, language); | ||||
| 
 | ||||
|         expect(result).toEqual([]); | ||||
|     }); | ||||
| }); | ||||
|  |  | |||
		Reference in a new issue
	
	 Joyelle Ndagijimana
						Joyelle Ndagijimana