59
									
								
								src/tests/scanstations/scanstations_get.spec.ts
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										59
									
								
								src/tests/scanstations/scanstations_get.spec.ts
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,59 @@
 | 
			
		||||
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('GET /api/stations sucessfully', () => {
 | 
			
		||||
	it('basic get should return 200', async () => {
 | 
			
		||||
		const res = await axios.get(base + '/api/stations', axios_config);
 | 
			
		||||
		expect(res.status).toEqual(200);
 | 
			
		||||
		expect(res.headers['content-type']).toContain("application/json")
 | 
			
		||||
	});
 | 
			
		||||
});
 | 
			
		||||
// ---------------
 | 
			
		||||
describe('GET /api/stations illegally', () => {
 | 
			
		||||
	it('get for non-existant track should return 404', async () => {
 | 
			
		||||
		const res = await axios.get(base + '/api/stations/-1', axios_config);
 | 
			
		||||
		expect(res.status).toEqual(404);
 | 
			
		||||
		expect(res.headers['content-type']).toContain("application/json")
 | 
			
		||||
	});
 | 
			
		||||
});
 | 
			
		||||
// ---------------
 | 
			
		||||
describe('adding + getting stations', () => {
 | 
			
		||||
	let added_track;
 | 
			
		||||
	let added_station;
 | 
			
		||||
	it('creating a track should return 200', async () => {
 | 
			
		||||
		const res1 = await axios.post(base + '/api/tracks', {
 | 
			
		||||
			"name": "test123",
 | 
			
		||||
			"distance": 123
 | 
			
		||||
		}, 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('check if station was added (no parameter validation)', async () => {
 | 
			
		||||
		const res = await axios.get(base + '/api/stations/' + added_station.id, axios_config);
 | 
			
		||||
		expect(res.status).toEqual(200);
 | 
			
		||||
		expect(res.headers['content-type']).toContain("application/json");
 | 
			
		||||
	});
 | 
			
		||||
});
 | 
			
		||||
		Reference in New Issue
	
	Block a user