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