mirror of
https://github.com/public-transport/db-vendo-client.git
synced 2025-02-23 07:09:35 +02:00
mobiliteit.lu: E2E/integration tests ✅
This commit is contained in:
parent
54b7d2845b
commit
78a0f0fa54
2 changed files with 268 additions and 0 deletions
|
@ -13,6 +13,7 @@ require('./nvv')
|
|||
require('./sbahn-muenchen')
|
||||
require('./saarfahrplan')
|
||||
require('./cfl')
|
||||
require('./mobiliteit-lu')
|
||||
require('./hvv')
|
||||
require('./vsn')
|
||||
require('./vbn')
|
||||
|
|
267
test/e2e/mobiliteit-lu.js
Normal file
267
test/e2e/mobiliteit-lu.js
Normal file
|
@ -0,0 +1,267 @@
|
|||
'use strict'
|
||||
|
||||
const assert = require('assert')
|
||||
const isRoughlyEqual = require('is-roughly-equal')
|
||||
|
||||
const {createWhen} = require('./lib/util')
|
||||
const createClient = require('../..')
|
||||
const mobiliteitLuProfile = require('../../p/mobiliteit-lu')
|
||||
const products = require('../../p/mobiliteit-lu/products')
|
||||
const {
|
||||
line: createValidateLine,
|
||||
journeyLeg: createValidateJourneyLeg,
|
||||
movement: _validateMovement
|
||||
} = require('./lib/validators')
|
||||
const createValidate = require('./lib/validate-fptf-with')
|
||||
const {test} = require('./lib/util')
|
||||
const testJourneysStationToStation = require('./lib/journeys-station-to-station')
|
||||
const testJourneysStationToAddress = require('./lib/journeys-station-to-address')
|
||||
const testJourneysStationToPoi = require('./lib/journeys-station-to-poi')
|
||||
const testEarlierLaterJourneys = require('./lib/earlier-later-journeys')
|
||||
const journeysFailsWithNoProduct = require('./lib/journeys-fails-with-no-product')
|
||||
const testDepartures = require('./lib/departures')
|
||||
const testArrivals = require('./lib/arrivals')
|
||||
|
||||
const when = createWhen('Europe/Berlin', 'de-DE')
|
||||
|
||||
const cfg = {
|
||||
when,
|
||||
products,
|
||||
minLatitude: 47.24,
|
||||
maxLatitude: 52.9,
|
||||
minLongitude: -0.63,
|
||||
maxLongitude: 14.07
|
||||
}
|
||||
|
||||
const _validateLine = createValidateLine(cfg)
|
||||
const validateLine = (validate, l, name) => {
|
||||
if (!l.direction) l = Object.assign({}, l, {direction: 'foo'})
|
||||
_validateLine(validate, l, name)
|
||||
}
|
||||
|
||||
const _validateJourneyLeg = createValidateJourneyLeg(cfg)
|
||||
const validateJourneyLeg = (validate, l, name) => {
|
||||
if (!l.direction) l = Object.assign({}, l, {direction: 'foo'})
|
||||
_validateJourneyLeg(validate, l, name)
|
||||
}
|
||||
|
||||
const validateMovement = (val, m, name = 'movement') => {
|
||||
// todo: fix this upstream
|
||||
const withFakeLocation = Object.assign({}, m)
|
||||
withFakeLocation.location = Object.assign({}, m.location, {
|
||||
latitude: 50,
|
||||
longitude: 12
|
||||
})
|
||||
_validateMovement(val, withFakeLocation, name)
|
||||
|
||||
assert.ok(m.location.latitude <= 55, name + '.location.latitude is too small')
|
||||
assert.ok(m.location.latitude >= 45, name + '.location.latitude is too large')
|
||||
assert.ok(m.location.longitude >= 1, name + '.location.longitude is too small')
|
||||
assert.ok(m.location.longitude <= 11, name + '.location.longitude is too small')
|
||||
}
|
||||
|
||||
const validate = createValidate(cfg, {
|
||||
line: validateLine,
|
||||
journeyLeg: validateJourneyLeg,
|
||||
movement: validateMovement
|
||||
})
|
||||
|
||||
const client = createClient(mobiliteitLuProfile, 'public-transport/hafas-client:test')
|
||||
|
||||
const ettelbruck = '140701016'
|
||||
const mersch = '160904011'
|
||||
const luxembourg = '200405060'
|
||||
|
||||
test('journeys – Ettelbruck to Luxembourg', async (t) => {
|
||||
const res = await client.journeys(ettelbruck, luxembourg, {
|
||||
results: 4,
|
||||
departure: when,
|
||||
stopovers: true
|
||||
})
|
||||
|
||||
await testJourneysStationToStation({
|
||||
test: t,
|
||||
res,
|
||||
validate,
|
||||
fromId: ettelbruck,
|
||||
toId: luxembourg
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
// todo: journeys, only one product
|
||||
|
||||
test('journeys – fails with no product', (t) => {
|
||||
journeysFailsWithNoProduct({
|
||||
test: t,
|
||||
fetchJourneys: client.journeys,
|
||||
fromId: ettelbruck,
|
||||
toId: luxembourg,
|
||||
when,
|
||||
products
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('Luxembourg to Ettelbruck, Rue des Romains 4', async (t) => {
|
||||
const rueDeRomain = {
|
||||
type: 'location',
|
||||
address: 'Ettelbruck, Rue des Romains 4',
|
||||
latitude: 49.847469,
|
||||
longitude: 6.097608
|
||||
}
|
||||
|
||||
const res = await client.journeys(luxembourg, rueDeRomain, {
|
||||
results: 3,
|
||||
departure: when
|
||||
})
|
||||
|
||||
await testJourneysStationToAddress({
|
||||
test: t,
|
||||
res,
|
||||
validate,
|
||||
fromId: luxembourg,
|
||||
to: rueDeRomain
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('Luxembourg to Centre Hospitalier du Nord', async (t) => {
|
||||
const centreHospitalier = {
|
||||
type: 'location',
|
||||
id: '140701020',
|
||||
poi: true,
|
||||
name: 'Ettelbruck, Centre Hospitalier du Nord',
|
||||
latitude: 49.853096,
|
||||
longitude: 6.094075
|
||||
}
|
||||
const res = await client.journeys(luxembourg, centreHospitalier, {
|
||||
results: 3,
|
||||
departure: when
|
||||
})
|
||||
|
||||
await testJourneysStationToPoi({
|
||||
test: t,
|
||||
res,
|
||||
validate,
|
||||
fromId: luxembourg,
|
||||
to: centreHospitalier
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
// todo: journeys: via works – with detour
|
||||
// todo: without detour
|
||||
|
||||
test('earlier/later journeys', async (t) => {
|
||||
await testEarlierLaterJourneys({
|
||||
test: t,
|
||||
fetchJourneys: client.journeys,
|
||||
validate,
|
||||
fromId: luxembourg,
|
||||
toId: ettelbruck,
|
||||
when,
|
||||
})
|
||||
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('trip', async (t) => {
|
||||
const { journeys } = await client.journeys(luxembourg, ettelbruck, {
|
||||
results: 1, departure: when
|
||||
})
|
||||
|
||||
const p = journeys[0].legs.find(l => !l.walking)
|
||||
t.ok(p.tripId, 'precondition failed')
|
||||
t.ok(p.line.name, 'precondition failed')
|
||||
const trip = await client.trip(p.tripId, p.line.name, {when})
|
||||
|
||||
validate(t, trip, 'trip', 'trip')
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('departures at Ettelbruck.', async (t) => {
|
||||
const departures = await client.departures(ettelbruck, {
|
||||
duration: 20, when
|
||||
})
|
||||
|
||||
await testDepartures({
|
||||
test: t,
|
||||
departures,
|
||||
validate,
|
||||
id: ettelbruck
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('arrivals at Ettelbruck.', async (t) => {
|
||||
const arrivals = await client.arrivals(ettelbruck, {
|
||||
duration: 20, when
|
||||
})
|
||||
|
||||
await testArrivals({
|
||||
test: t,
|
||||
arrivals,
|
||||
validate,
|
||||
id: ettelbruck
|
||||
})
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('departures with station object', async (t) => {
|
||||
const deps = await client.departures({
|
||||
type: 'station',
|
||||
id: ettelbruck,
|
||||
name: 'Ettelbruck',
|
||||
location: {
|
||||
type: 'location',
|
||||
latitude: 49.847298,
|
||||
longitude: 6.106157
|
||||
}
|
||||
}, {when})
|
||||
|
||||
validate(t, deps, 'departures', 'departures')
|
||||
t.end()
|
||||
})
|
||||
|
||||
// todo: nearby
|
||||
|
||||
test('locations named Mersch', async (t) => {
|
||||
const locations = await client.locations('Mersch', {
|
||||
results: 20
|
||||
})
|
||||
|
||||
validate(t, locations, 'locations', 'locations')
|
||||
t.ok(locations.length <= 20)
|
||||
|
||||
t.ok(locations.find(s => s.type === 'stop' || s.type === 'station'))
|
||||
t.ok(locations.some((loc) => {
|
||||
if (loc.station && loc.station.id === mersch) return true
|
||||
return loc.id === mersch
|
||||
}))
|
||||
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('stop Mersch', async (t) => {
|
||||
const s = await client.stop(mersch)
|
||||
|
||||
validate(t, s, ['stop', 'station'], 'stop')
|
||||
t.equal(s.id, mersch)
|
||||
|
||||
t.end()
|
||||
})
|
||||
|
||||
test('radar', async (t) => {
|
||||
const vehicles = await client.radar({
|
||||
north: 49.9,
|
||||
west: 6.05,
|
||||
south: 49.8,
|
||||
east: 6.15
|
||||
}, {
|
||||
duration: 5 * 60, when, results: 10
|
||||
})
|
||||
|
||||
validate(t, vehicles, 'movements', 'vehicles')
|
||||
t.end()
|
||||
})
|
Loading…
Add table
Reference in a new issue