test(backend): Testen voor LearningPathService toegevoegd
This commit is contained in:
		
							parent
							
								
									cb6056e9d7
								
							
						
					
					
						commit
						392510db82
					
				
					 12 changed files with 114 additions and 8 deletions
				
			
		|  | @ -24,7 +24,7 @@ const learningPathService = { | ||||||
|         const userContentLearningPaths = |         const userContentLearningPaths = | ||||||
|             await databaseLearningPathProvider.fetchLearningPaths(userContentHruids, language, source); |             await databaseLearningPathProvider.fetchLearningPaths(userContentHruids, language, source); | ||||||
|         const nonUserContentLearningPaths |         const nonUserContentLearningPaths | ||||||
|             = await databaseLearningPathProvider.fetchLearningPaths(nonUserContentHruids, language, source); |             = await dwengoApiLearningPathProvider.fetchLearningPaths(nonUserContentHruids, language, source); | ||||||
| 
 | 
 | ||||||
|         return { |         return { | ||||||
|             data: (userContentLearningPaths.data || []).concat(nonUserContentLearningPaths.data || []), |             data: (userContentLearningPaths.data || []).concat(nonUserContentLearningPaths.data || []), | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ import {setupTestApp} from "../../setup-tests"; | ||||||
| import {getAttachmentRepository, getLearningObjectRepository} from "../../../src/data/repositories"; | import {getAttachmentRepository, getLearningObjectRepository} from "../../../src/data/repositories"; | ||||||
| import {AttachmentRepository} from "../../../src/data/content/attachment-repository"; | import {AttachmentRepository} from "../../../src/data/content/attachment-repository"; | ||||||
| import {LearningObjectRepository} from "../../../src/data/content/learning-object-repository"; | import {LearningObjectRepository} from "../../../src/data/content/learning-object-repository"; | ||||||
| import example from "../../test-assets/learning-objects/pn_werkingnotebooks/pn-werkingnotebooks-example"; | import example from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example"; | ||||||
| import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | ||||||
| import {Attachment} from "../../../src/entities/content/attachment.entity"; | import {Attachment} from "../../../src/entities/content/attachment.entity"; | ||||||
| import {LearningObjectIdentifier} from "../../../src/entities/content/learning-object-identifier"; | import {LearningObjectIdentifier} from "../../../src/entities/content/learning-object-identifier"; | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import {beforeAll, describe, it, expect} from "vitest"; | ||||||
| import {LearningObjectRepository} from "../../../src/data/content/learning-object-repository"; | import {LearningObjectRepository} from "../../../src/data/content/learning-object-repository"; | ||||||
| import {setupTestApp} from "../../setup-tests"; | import {setupTestApp} from "../../setup-tests"; | ||||||
| import {getLearningObjectRepository} from "../../../src/data/repositories"; | import {getLearningObjectRepository} from "../../../src/data/repositories"; | ||||||
| import example from "../../test-assets/learning-objects/pn_werkingnotebooks/pn-werkingnotebooks-example.js" | import example from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example.js" | ||||||
| import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | ||||||
| import {expectToBeCorrectEntity} from "../../test-utils/expectations"; | import {expectToBeCorrectEntity} from "../../test-utils/expectations"; | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,7 +1,7 @@ | ||||||
| import {beforeAll, describe, expect, it} from "vitest"; | import {beforeAll, describe, expect, it} from "vitest"; | ||||||
| import {setupTestApp} from "../../setup-tests"; | import {setupTestApp} from "../../setup-tests"; | ||||||
| import {getLearningObjectRepository} from "../../../src/data/repositories"; | import {getLearningObjectRepository} from "../../../src/data/repositories"; | ||||||
| import example from "../../test-assets/learning-objects/pn_werkingnotebooks/pn-werkingnotebooks-example"; | import example from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example"; | ||||||
| import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | ||||||
| import databaseLearningObjectProvider from "../../../src/services/learning-objects/database-learning-object-provider"; | import databaseLearningObjectProvider from "../../../src/services/learning-objects/database-learning-object-provider"; | ||||||
| import { | import { | ||||||
|  |  | ||||||
|  | @ -2,7 +2,7 @@ import {beforeAll, describe, expect, it} from "vitest"; | ||||||
| import {setupTestApp} from "../../setup-tests"; | import {setupTestApp} from "../../setup-tests"; | ||||||
| import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | ||||||
| import {getLearningObjectRepository} from "../../../src/data/repositories"; | import {getLearningObjectRepository} from "../../../src/data/repositories"; | ||||||
| import learningObjectExample from "../../test-assets/learning-objects/pn_werkingnotebooks/pn-werkingnotebooks-example"; | import learningObjectExample from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example"; | ||||||
| import learningObjectService from "../../../src/services/learning-objects/learning-object-service"; | import learningObjectService from "../../../src/services/learning-objects/learning-object-service"; | ||||||
| import {LearningObjectIdentifier} from "../../../src/interfaces/learning-content"; | import {LearningObjectIdentifier} from "../../../src/interfaces/learning-content"; | ||||||
| import {Language} from "../../../src/entities/content/language"; | import {Language} from "../../../src/entities/content/language"; | ||||||
|  | @ -11,7 +11,7 @@ import {EnvVars, getEnvVar} from "../../../src/util/envvars"; | ||||||
| const TEST_LEARNING_OBJECT_TITLE = "Test title"; | const TEST_LEARNING_OBJECT_TITLE = "Test title"; | ||||||
| const EXPECTED_DWENGO_LEARNING_OBJECT_TITLE = "Werken met notebooks"; | const EXPECTED_DWENGO_LEARNING_OBJECT_TITLE = "Werken met notebooks"; | ||||||
| const DWENGO_TEST_LEARNING_OBJECT_ID: LearningObjectIdentifier = { | const DWENGO_TEST_LEARNING_OBJECT_ID: LearningObjectIdentifier = { | ||||||
|     hruid: "pn_werkingnotebooks", |     hruid: "pn-werkingnotebooks", | ||||||
|     language: Language.Dutch, |     language: Language.Dutch, | ||||||
|     version: 3 |     version: 3 | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  | @ -3,7 +3,7 @@ import {LearningObject} from "../../../src/entities/content/learning-object.enti | ||||||
| import {setupTestApp} from "../../setup-tests"; | import {setupTestApp} from "../../setup-tests"; | ||||||
| import {LearningPath} from "../../../src/entities/content/learning-path.entity"; | import {LearningPath} from "../../../src/entities/content/learning-path.entity"; | ||||||
| import {getLearningObjectRepository, getLearningPathRepository} from "../../../src/data/repositories"; | import {getLearningObjectRepository, getLearningPathRepository} from "../../../src/data/repositories"; | ||||||
| import learningObjectExample from "../../test-assets/learning-objects/pn_werkingnotebooks/pn-werkingnotebooks-example"; | import learningObjectExample from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example"; | ||||||
| import learningPathExample from "../../test-assets/learning-paths/pn-werking-example" | import learningPathExample from "../../test-assets/learning-paths/pn-werking-example" | ||||||
| import databaseLearningPathProvider from "../../../src/services/learning-paths/database-learning-path-provider"; | import databaseLearningPathProvider from "../../../src/services/learning-paths/database-learning-path-provider"; | ||||||
| import {expectToBeCorrectLearningPath} from "../../test-utils/expectations"; | import {expectToBeCorrectLearningPath} from "../../test-utils/expectations"; | ||||||
|  |  | ||||||
|  | @ -0,0 +1,106 @@ | ||||||
|  | import {beforeAll, describe, expect, it} from "vitest"; | ||||||
|  | import {setupTestApp} from "../../setup-tests"; | ||||||
|  | import {LearningObject} from "../../../src/entities/content/learning-object.entity"; | ||||||
|  | import {LearningPath} from "../../../src/entities/content/learning-path.entity"; | ||||||
|  | import {getLearningObjectRepository, getLearningPathRepository} from "../../../src/data/repositories"; | ||||||
|  | import learningObjectExample from "../../test-assets/learning-objects/pn-werkingnotebooks/pn-werkingnotebooks-example"; | ||||||
|  | import learningPathExample from "../../test-assets/learning-paths/pn-werking-example"; | ||||||
|  | import {Language} from "../../../src/entities/content/language"; | ||||||
|  | import learningPathService from "../../../src/services/learning-paths/learning-path-service"; | ||||||
|  | 
 | ||||||
|  | async function initExampleData(): Promise<{ learningObject: LearningObject, learningPath: LearningPath }> { | ||||||
|  |     const learningObjectRepo = getLearningObjectRepository(); | ||||||
|  |     const learningPathRepo = getLearningPathRepository(); | ||||||
|  |     let learningObject = learningObjectExample.createLearningObject(); | ||||||
|  |     let learningPath = learningPathExample.createLearningPath(); | ||||||
|  |     await learningObjectRepo.save(learningObject); | ||||||
|  |     await learningPathRepo.save(learningPath); | ||||||
|  |     return { learningObject, learningPath }; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | const TEST_DWENGO_LEARNING_PATH_HRUID = "pn_werking"; | ||||||
|  | const TEST_DWENGO_LEARNING_PATH_TITLE = "Werken met notebooks"; | ||||||
|  | const TEST_DWENGO_EXCLUSIVE_LEARNING_PATH_SEARCH_QUERY = "Microscopie"; | ||||||
|  | const TEST_SEARCH_QUERY_EXPECTING_NO_MATCHES = "su$m8f9usf89ud<p9<U8SDP8UP9"; | ||||||
|  | 
 | ||||||
|  | describe("LearningPathService", () => { | ||||||
|  |     let example: { learningObject: LearningObject, learningPath: LearningPath }; | ||||||
|  |     beforeAll(async () => { | ||||||
|  |         await setupTestApp(); | ||||||
|  |         example = await initExampleData(); | ||||||
|  |     }); | ||||||
|  |     describe("fetchLearningPaths", () => { | ||||||
|  |         it("should return learning paths both from the database and from the Dwengo API", async () => { | ||||||
|  |             const result = await learningPathService.fetchLearningPaths( | ||||||
|  |                 [example.learningPath.hruid, TEST_DWENGO_LEARNING_PATH_HRUID], | ||||||
|  |                 example.learningPath.language, | ||||||
|  |                 "the source" | ||||||
|  |             ); | ||||||
|  |             expect(result.success).toBeTruthy(); | ||||||
|  |             expect(result.data?.filter(it => it.hruid == TEST_DWENGO_LEARNING_PATH_HRUID).length).not.toBe(0); | ||||||
|  |             expect(result.data?.filter(it => it.hruid == example.learningPath.hruid).length).not.toBe(0); | ||||||
|  |             expect(result.data?.filter(it => it.hruid == TEST_DWENGO_LEARNING_PATH_HRUID)[0].title) | ||||||
|  |                 .toEqual(TEST_DWENGO_LEARNING_PATH_TITLE); | ||||||
|  |             expect(result.data?.filter(it => it.hruid == example.learningPath.hruid)[0].title) | ||||||
|  |                 .toEqual(example.learningPath.title); | ||||||
|  |         }); | ||||||
|  |         it("should include both the learning objects from the Dwengo API and learning objects from the database in its response", async () => { | ||||||
|  |             const result = await learningPathService.fetchLearningPaths( | ||||||
|  |                 [example.learningPath.hruid], | ||||||
|  |                 example.learningPath.language, | ||||||
|  |                 "the source" | ||||||
|  |             ); | ||||||
|  |             expect(result.success).toBeTruthy(); | ||||||
|  |             expect(result.data?.length).toBe(1); | ||||||
|  | 
 | ||||||
|  |             // Should include all the nodes, even those pointing to foreign learning objects.
 | ||||||
|  |             expect( | ||||||
|  |                 [...result.data![0].nodes.map(it => it.learningobject_hruid)].sort() | ||||||
|  |             ).toEqual( | ||||||
|  |                 example.learningPath.nodes.map(it => it.learningObjectHruid).sort() | ||||||
|  |             ); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  |     describe("searchLearningPath", () => { | ||||||
|  |         it("should include both the learning paths from the Dwengo API and those from the database in its response", async () => { | ||||||
|  |             // This matches the learning object in the database, but definitely also some learning objects in the Dwengo API.
 | ||||||
|  |             const result = await learningPathService.searchLearningPaths( | ||||||
|  |                 example.learningPath.title.substring(2, 3), | ||||||
|  |                 example.learningPath.language | ||||||
|  |             ); | ||||||
|  | 
 | ||||||
|  |             // Should find the one from the database
 | ||||||
|  |             expect( | ||||||
|  |                 result.filter(it => | ||||||
|  |                     it.hruid === example.learningPath.hruid && it.title === example.learningPath.title | ||||||
|  |                 ).length | ||||||
|  |             ).toBe(1); | ||||||
|  | 
 | ||||||
|  |             // but should not only find that one.
 | ||||||
|  |             expect(result.length).not.toBeLessThan(2); | ||||||
|  |         }); | ||||||
|  |         it("should still return results from the Dwengo API even though there are no matches in the database", async () => { | ||||||
|  |             const result = await learningPathService.searchLearningPaths( | ||||||
|  |                 TEST_DWENGO_EXCLUSIVE_LEARNING_PATH_SEARCH_QUERY, | ||||||
|  |                 Language.Dutch | ||||||
|  |             ); | ||||||
|  | 
 | ||||||
|  |             // Should find something...
 | ||||||
|  |             expect(result.length).not.toBe(0); | ||||||
|  | 
 | ||||||
|  |             // but not the example learning path.
 | ||||||
|  |             expect( | ||||||
|  |                 result.filter(it => | ||||||
|  |                     it.hruid === example.learningPath.hruid && it.title === example.learningPath.title | ||||||
|  |                 ).length | ||||||
|  |             ).toBe(0); | ||||||
|  |         }); | ||||||
|  |         it("should return an empty list if neither the Dwengo API nor the database contains matches", async () => { | ||||||
|  |             const result = await learningPathService.searchLearningPaths( | ||||||
|  |                 TEST_SEARCH_QUERY_EXPECTING_NO_MATCHES, | ||||||
|  |                 Language.Dutch | ||||||
|  |             ); | ||||||
|  |             expect(result.length).toBe(0); | ||||||
|  |         }); | ||||||
|  |     }); | ||||||
|  | }); | ||||||
| Before Width: | Height: | Size: 7.6 KiB After Width: | Height: | Size: 7.6 KiB | 
| Before Width: | Height: | Size: 31 KiB After Width: | Height: | Size: 31 KiB | 
|  | @ -6,7 +6,7 @@ import {EducationalGoal, LearningObject, ReturnValue} from "../../../../src/enti | ||||||
| import {Attachment} from "../../../../src/entities/content/attachment.entity"; | import {Attachment} from "../../../../src/entities/content/attachment.entity"; | ||||||
| import {EnvVars, getEnvVar} from "../../../../src/util/envvars"; | import {EnvVars, getEnvVar} from "../../../../src/util/envvars"; | ||||||
| 
 | 
 | ||||||
| const ASSETS_PREFIX = "learning-objects/pn_werkingnotebooks/"; | const ASSETS_PREFIX = "learning-objects/pn-werkingnotebooks/"; | ||||||
| 
 | 
 | ||||||
| const example: LearningObjectExample = { | const example: LearningObjectExample = { | ||||||
|     createLearningObject: ()=>  { |     createLearningObject: ()=>  { | ||||||
		Reference in a new issue
	
	 Gerald Schmittinger
						Gerald Schmittinger