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:
parent
efe1a1f543
commit
7e95103a2d
@ -1,4 +1,4 @@
|
|||||||
import { IsBoolean, IsInt, IsOptional, IsPositive } from 'class-validator';
|
import { IsBoolean, IsInt, IsOptional } from 'class-validator';
|
||||||
import { getConnection } from 'typeorm';
|
import { getConnection } from 'typeorm';
|
||||||
import { RunnerNotFoundError } from '../../errors/RunnerErrors';
|
import { RunnerNotFoundError } from '../../errors/RunnerErrors';
|
||||||
import { ScanStationNotFoundError } from '../../errors/ScanStationErrors';
|
import { ScanStationNotFoundError } from '../../errors/ScanStationErrors';
|
||||||
@ -22,8 +22,8 @@ export abstract class UpdateTrackScan {
|
|||||||
* This is important to link ran distances to runners.
|
* This is important to link ran distances to runners.
|
||||||
*/
|
*/
|
||||||
@IsInt()
|
@IsInt()
|
||||||
@IsPositive()
|
@IsOptional()
|
||||||
runner: number;
|
runner?: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Is the updated scan valid (for fraud reasons).
|
* Is the updated scan valid (for fraud reasons).
|
||||||
@ -46,7 +46,9 @@ export abstract class UpdateTrackScan {
|
|||||||
*/
|
*/
|
||||||
public async updateScan(scan: TrackScan): Promise<TrackScan> {
|
public async updateScan(scan: TrackScan): Promise<TrackScan> {
|
||||||
scan.valid = this.valid;
|
scan.valid = this.valid;
|
||||||
|
if (this.runner) {
|
||||||
scan.runner = await this.getRunner();
|
scan.runner = await this.getRunner();
|
||||||
|
}
|
||||||
if (this.station) {
|
if (this.station) {
|
||||||
scan.station = await this.getStation();
|
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")
|
||||||
|
});
|
||||||
|
});
|
Loading…
x
Reference in New Issue
Block a user