Added scan add tests with the station based auth

ref #67
This commit is contained in:
Nicolai Ort 2021-01-08 18:09:47 +01:00
parent cf86520fae
commit a005945e9e
1 changed files with 96 additions and 0 deletions

View File

@ -133,3 +133,99 @@ describe('POST /api/scans successfully', () => {
});
});
});
// ---------------
describe('POST /api/scans successfully via scan station', () => {
let added_org;
let added_runner;
let added_track;
let added_station;
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);
delete res2.data.group;
added_runner = res2.data;
expect(res2.status).toEqual(200);
expect(res2.headers['content-type']).toContain("application/json")
});
it('creating a track with the minimum amount of parameters should return 200', async () => {
const res = await axios.post(base + '/api/tracks', {
"name": "testtrack",
"distance": 200,
}, axios_config);
added_track = res.data;
expect(res.status).toEqual(200);
expect(res.headers['content-type']).toContain("application/json");
});
it('creating a station with minimum parameters should return 200', async () => {
const res = await axios.post(base + '/api/stations', {
"track": added_track.id
}, axios_config);
added_station = res.data;
expect(res.status).toEqual(200);
expect(res.headers['content-type']).toContain("application/json");
});
it('creating a scan with the minimum amount of parameters should return 200', async () => {
const res = await axios.post(base + '/api/scans', {
"runner": added_runner.id,
"distance": 200
}, {
headers: { "authorization": "Bearer " + added_station.key },
validateStatus: undefined
});
expect(res.status).toEqual(200);
expect(res.headers['content-type']).toContain("application/json");
delete res.data.id;
expect(res.data).toEqual({
"runner": added_runner,
"distance": 200,
"valid": true
});
});
it('creating a valid scan should return 200', async () => {
const res = await axios.post(base + '/api/scans', {
"runner": added_runner.id,
"distance": 200,
"valid": true
}, {
headers: { "authorization": "Bearer " + added_station.key },
validateStatus: undefined
});
expect(res.status).toEqual(200);
expect(res.headers['content-type']).toContain("application/json");
delete res.data.id;
expect(res.data).toEqual({
"runner": added_runner,
"distance": 200,
"valid": true
});
});
it('creating a invalid scan should return 200', async () => {
const res = await axios.post(base + '/api/scans', {
"runner": added_runner.id,
"distance": 200,
"valid": false
}, {
headers: { "authorization": "Bearer " + added_station.key },
validateStatus: undefined
});
expect(res.status).toEqual(200);
expect(res.headers['content-type']).toContain("application/json");
delete res.data.id;
expect(res.data).toEqual({
"runner": added_runner,
"distance": 200,
"valid": false
});
});
});