added trackscan update tests
	
		
			
	
		
	
	
		
	
		
			All checks were successful
		
		
	
	
		
			
				
	
				continuous-integration/drone/pr Build is passing
				
			
		
		
	
	
				
					
				
			
		
			All checks were successful
		
		
	
	continuous-integration/drone/pr Build is passing
				
			ref #78
This commit is contained in:
		| @@ -1,4 +1,4 @@ | ||||
| import { IsBoolean, IsInt, IsOptional, IsPositive } from 'class-validator'; | ||||
| import { IsBoolean, IsInt, IsOptional } from 'class-validator'; | ||||
| import { getConnection } from 'typeorm'; | ||||
| import { RunnerNotFoundError } from '../../errors/RunnerErrors'; | ||||
| import { ScanStationNotFoundError } from '../../errors/ScanStationErrors'; | ||||
| @@ -22,8 +22,8 @@ export abstract class UpdateTrackScan { | ||||
|      * This is important to link ran distances to runners. | ||||
|      */ | ||||
|     @IsInt() | ||||
|     @IsPositive() | ||||
|     runner: number; | ||||
|     @IsOptional() | ||||
|     runner?: number; | ||||
|  | ||||
|     /** | ||||
|      * Is the updated scan valid (for fraud reasons). | ||||
| @@ -46,7 +46,9 @@ export abstract class UpdateTrackScan { | ||||
|      */ | ||||
|     public async updateScan(scan: TrackScan): Promise<TrackScan> { | ||||
|         scan.valid = this.valid; | ||||
|         scan.runner = await this.getRunner(); | ||||
|         if (this.runner) { | ||||
|             scan.runner = await this.getRunner(); | ||||
|         } | ||||
|         if (this.station) { | ||||
|             scan.station = await this.getStation(); | ||||
|         } | ||||
|   | ||||
							
								
								
									
										239
									
								
								src/tests/trackscans/trackscans_update.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										239
									
								
								src/tests/trackscans/trackscans_update.spec.ts
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,239 @@ | ||||
| import axios from 'axios'; | ||||
| import { config } from '../../config'; | ||||
| const base = "http://localhost:" + config.internal_port | ||||
|  | ||||
| let access_token; | ||||
| let axios_config; | ||||
|  | ||||
| beforeAll(async () => { | ||||
| 	const res = await axios.post(base + '/api/auth/login', { username: "demo", password: "demo" }); | ||||
| 	access_token = res.data["access_token"]; | ||||
| 	axios_config = { | ||||
| 		headers: { "authorization": "Bearer " + access_token }, | ||||
| 		validateStatus: undefined | ||||
| 	}; | ||||
| }); | ||||
|  | ||||
| describe('adding + updating illegally', () => { | ||||
| 	let added_org; | ||||
| 	let added_runner; | ||||
| 	let added_card; | ||||
| 	let added_track; | ||||
| 	let added_station; | ||||
| 	let added_scan; | ||||
| 	it('creating a new org with just a name should return 200', async () => { | ||||
| 		const res1 = await axios.post(base + '/api/organisations', { | ||||
| 			"name": "test123" | ||||
| 		}, axios_config); | ||||
| 		added_org = res1.data | ||||
| 		expect(res1.status).toEqual(200); | ||||
| 		expect(res1.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a new runner with only needed params should return 200', async () => { | ||||
| 		const res2 = await axios.post(base + '/api/runners', { | ||||
| 			"firstname": "first", | ||||
| 			"lastname": "last", | ||||
| 			"group": added_org.id | ||||
| 		}, axios_config); | ||||
| 		added_runner = res2.data; | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a card with the minimum amount of parameters should return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/cards', { | ||||
| 			"runner": added_runner.id | ||||
| 		}, axios_config); | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json"); | ||||
| 		added_card = res.data; | ||||
| 	}); | ||||
| 	it('creating a track should return 200', async () => { | ||||
| 		const res1 = await axios.post(base + '/api/tracks', { | ||||
| 			"name": "test123", | ||||
| 			"distance": 123, | ||||
| 			"minimumLapTime": 30 | ||||
| 		}, axios_config); | ||||
| 		added_track = res1.data | ||||
| 		expect(res1.status).toEqual(200); | ||||
| 		expect(res1.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('correct description and track input for station creation return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/stations', { | ||||
| 			"track": added_track.id, | ||||
| 			"description": "I am but a simple test." | ||||
| 		}, axios_config); | ||||
| 		added_station = res.data; | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a scan should return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/scans/trackscans', { | ||||
| 			"card": added_card.id, | ||||
| 			"station": added_station.id | ||||
| 		}, { | ||||
| 			headers: { "authorization": "Bearer " + added_station.key }, | ||||
| 			validateStatus: undefined | ||||
| 		}); | ||||
| 		added_scan = res.data; | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json"); | ||||
| 	}); | ||||
| 	it('updating empty should return 400', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, null, axios_config); | ||||
| 		expect(res2.status).toEqual(400); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('updating with wrong id should return 406', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id + 1, | ||||
| 			"station": added_station.id, | ||||
| 			"runner": added_runner.id | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(406); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('updating with invalid station should return 404', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id, | ||||
| 			"station": 9999999999999999, | ||||
| 			"runner": added_runner.id | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(404); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('updating with invalid runner should return 404', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id, | ||||
| 			"station": added_station.id, | ||||
| 			"runner": 9999999999999999999 | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(404); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| }); | ||||
| //--------------- | ||||
| describe('adding + updating successfilly', () => { | ||||
| 	let added_org; | ||||
| 	let added_runner; | ||||
| 	let added_runner2; | ||||
| 	let added_card; | ||||
| 	let added_track; | ||||
| 	let added_track2; | ||||
| 	let added_station; | ||||
| 	let added_station2; | ||||
| 	let added_scan; | ||||
| 	it('creating a new org with just a name should return 200', async () => { | ||||
| 		const res1 = await axios.post(base + '/api/organisations', { | ||||
| 			"name": "test123" | ||||
| 		}, axios_config); | ||||
| 		added_org = res1.data | ||||
| 		expect(res1.status).toEqual(200); | ||||
| 		expect(res1.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a new runner with only needed params should return 200', async () => { | ||||
| 		const res2 = await axios.post(base + '/api/runners', { | ||||
| 			"firstname": "first", | ||||
| 			"lastname": "last", | ||||
| 			"group": added_org.id | ||||
| 		}, axios_config); | ||||
| 		added_runner = res2.data; | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a new runner with only needed params should return 200', async () => { | ||||
| 		const res2 = await axios.post(base + '/api/runners', { | ||||
| 			"firstname": "first", | ||||
| 			"lastname": "last", | ||||
| 			"group": added_org.id | ||||
| 		}, axios_config); | ||||
| 		added_runner2 = res2.data; | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a card with the minimum amount of parameters should return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/cards', { | ||||
| 			"runner": added_runner.id | ||||
| 		}, axios_config); | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json"); | ||||
| 		added_card = res.data; | ||||
| 	}); | ||||
| 	it('creating a track should return 200', async () => { | ||||
| 		const res1 = await axios.post(base + '/api/tracks', { | ||||
| 			"name": "test123", | ||||
| 			"distance": 123, | ||||
| 			"minimumLapTime": 30 | ||||
| 		}, axios_config); | ||||
| 		added_track = res1.data | ||||
| 		expect(res1.status).toEqual(200); | ||||
| 		expect(res1.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a track should return 200', async () => { | ||||
| 		const res1 = await axios.post(base + '/api/tracks', { | ||||
| 			"name": "test123", | ||||
| 			"distance": 123, | ||||
| 			"minimumLapTime": 30 | ||||
| 		}, axios_config); | ||||
| 		added_track2 = res1.data | ||||
| 		expect(res1.status).toEqual(200); | ||||
| 		expect(res1.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('correct description and track input for station creation return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/stations', { | ||||
| 			"track": added_track.id, | ||||
| 			"description": "I am but a simple test." | ||||
| 		}, axios_config); | ||||
| 		added_station = res.data; | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('correct description and track input for station creation return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/stations', { | ||||
| 			"track": added_track.id, | ||||
| 			"description": "I am but a simple test." | ||||
| 		}, axios_config); | ||||
| 		added_station2 = res.data; | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('creating a scan should return 200', async () => { | ||||
| 		const res = await axios.post(base + '/api/scans/trackscans', { | ||||
| 			"card": added_card.id, | ||||
| 			"station": added_station.id | ||||
| 		}, { | ||||
| 			headers: { "authorization": "Bearer " + added_station.key }, | ||||
| 			validateStatus: undefined | ||||
| 		}); | ||||
| 		added_scan = res.data; | ||||
| 		expect(res.status).toEqual(200); | ||||
| 		expect(res.headers['content-type']).toContain("application/json"); | ||||
| 	}); | ||||
| 	it('updating with new runner should return 200', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id, | ||||
| 			"station": added_station.id, | ||||
| 			"runner": added_runner2.id | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('updating with new station should return 200', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id, | ||||
| 			"station": added_station2.id, | ||||
| 			"runner": added_runner.id | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| 	it('updating with valid=false should return 200', async () => { | ||||
| 		const res2 = await axios.put(base + '/api/scans/trackscans/' + added_scan.id, { | ||||
| 			"id": added_scan.id, | ||||
| 			"station": added_station2.id, | ||||
| 			"runner": added_runner.id, | ||||
| 			"valid": false | ||||
| 		}, axios_config); | ||||
| 		expect(res2.status).toEqual(200); | ||||
| 		expect(res2.headers['content-type']).toContain("application/json") | ||||
| 	}); | ||||
| }); | ||||
		Reference in New Issue
	
	Block a user