2018-08-18 20:08:28 +03:00
|
|
|
extern crate control;
|
|
|
|
extern crate dimensioned;
|
|
|
|
extern crate geom;
|
|
|
|
extern crate map_model;
|
|
|
|
extern crate sim;
|
|
|
|
|
|
|
|
use map_model::LaneID;
|
|
|
|
|
|
|
|
// TODO refactor a few more things to make these more succinct?
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn park_on_goal_st() {
|
2018-08-27 20:18:08 +03:00
|
|
|
let (map, control_map, mut sim) = setup("park_on_goal_st", make_test_map());
|
2018-08-18 20:08:28 +03:00
|
|
|
let (parking1, parking2, driving2) = (LaneID(1), LaneID(4), LaneID(3));
|
|
|
|
|
|
|
|
assert_eq!(map.get_l(parking1).number_parking_spots(), 8);
|
|
|
|
assert_eq!(map.get_l(parking2).number_parking_spots(), 8);
|
|
|
|
let car = sim.seed_specific_parked_cars(parking1, (0..8).collect())[2];
|
|
|
|
sim.seed_specific_parked_cars(parking2, (0..4).collect());
|
|
|
|
sim.seed_specific_parked_cars(parking2, (5..8).collect());
|
|
|
|
sim.start_parked_car_with_goal(&map, car, driving2);
|
|
|
|
|
2018-08-30 21:04:27 +03:00
|
|
|
sim::init::run_until_expectations_met(
|
2018-08-28 00:00:52 +03:00
|
|
|
&mut sim,
|
|
|
|
&map,
|
|
|
|
&control_map,
|
2018-08-30 21:04:27 +03:00
|
|
|
vec![sim::Event::CarReachedParkingSpot(sim::ParkedCar::new(
|
|
|
|
car,
|
|
|
|
sim::ParkingSpot::new(parking2, 4),
|
|
|
|
))],
|
|
|
|
sim::Tick::from_minutes(1),
|
2018-08-28 00:00:52 +03:00
|
|
|
);
|
2018-08-30 21:04:27 +03:00
|
|
|
sim::init::run_until_done(&mut sim, &map, &control_map, Box::new(|_sim| {}));
|
2018-08-18 20:08:28 +03:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn wander_around_for_parking() {
|
2018-08-27 20:18:08 +03:00
|
|
|
let (map, control_map, mut sim) = setup("wander_around_for_parking", make_test_map());
|
2018-08-18 20:08:28 +03:00
|
|
|
let (parking1, parking2, driving2) = (LaneID(1), LaneID(4), LaneID(3));
|
|
|
|
|
|
|
|
assert_eq!(map.get_l(parking1).number_parking_spots(), 8);
|
|
|
|
assert_eq!(map.get_l(parking2).number_parking_spots(), 8);
|
|
|
|
// There's a free spot behind the car, so they have to loop around to their original lane to
|
|
|
|
// find it.
|
|
|
|
let car = sim.seed_specific_parked_cars(parking1, (1..8).collect())[2];
|
|
|
|
sim.seed_specific_parked_cars(parking2, (0..8).collect());
|
|
|
|
sim.start_parked_car_with_goal(&map, car, driving2);
|
|
|
|
|
2018-08-30 21:04:27 +03:00
|
|
|
sim::init::run_until_expectations_met(
|
2018-08-28 00:00:52 +03:00
|
|
|
&mut sim,
|
|
|
|
&map,
|
|
|
|
&control_map,
|
2018-08-30 21:04:27 +03:00
|
|
|
vec![sim::Event::CarReachedParkingSpot(sim::ParkedCar::new(
|
|
|
|
car,
|
|
|
|
sim::ParkingSpot::new(parking1, 0),
|
|
|
|
))],
|
|
|
|
sim::Tick::from_minutes(2),
|
2018-08-28 00:00:52 +03:00
|
|
|
);
|
2018-08-30 21:04:27 +03:00
|
|
|
sim::init::run_until_done(&mut sim, &map, &control_map, Box::new(|_sim| {}));
|
2018-08-18 20:08:28 +03:00
|
|
|
}
|
|
|
|
|
2018-08-27 20:18:08 +03:00
|
|
|
fn setup(
|
|
|
|
scenario_name: &str,
|
|
|
|
map: map_model::Map,
|
|
|
|
) -> (map_model::Map, control::ControlMap, sim::Sim) {
|
2018-08-18 20:08:28 +03:00
|
|
|
let rng_seed = 123;
|
|
|
|
let control_map = control::ControlMap::new(&map);
|
2018-08-27 23:29:00 +03:00
|
|
|
let sim = sim::Sim::new(&map, scenario_name.to_string(), Some(rng_seed), None);
|
2018-08-18 20:08:28 +03:00
|
|
|
(map, control_map, sim)
|
|
|
|
}
|
|
|
|
|
|
|
|
// Creates a test map with a single two-way road
|
|
|
|
fn make_test_map() -> map_model::Map {
|
|
|
|
use dimensioned::si;
|
|
|
|
use map_model::{raw_data, LaneType};
|
|
|
|
use std::collections::BTreeMap;
|
|
|
|
|
|
|
|
let left = geom::LonLat::new(100.0, 50.0);
|
|
|
|
let right = geom::LonLat::new(200.0, 50.0);
|
|
|
|
|
2018-08-23 20:19:09 +03:00
|
|
|
let north_pts = triangle_around(150.0, 10.0);
|
|
|
|
let south_pts = triangle_around(150.0, 90.0);
|
|
|
|
|
2018-08-18 20:08:28 +03:00
|
|
|
let map = map_model::Map::create_from_raw(
|
2018-08-27 20:18:08 +03:00
|
|
|
"test_map".to_string(),
|
2018-08-18 20:08:28 +03:00
|
|
|
raw_data::Map {
|
|
|
|
roads: vec![raw_data::Road {
|
|
|
|
points: vec![left, right],
|
|
|
|
osm_tags: BTreeMap::new(),
|
|
|
|
osm_way_id: 123,
|
|
|
|
}],
|
|
|
|
intersections: vec![
|
|
|
|
raw_data::Intersection {
|
|
|
|
point: left,
|
|
|
|
elevation: 0.0 * si::M,
|
|
|
|
has_traffic_signal: false,
|
|
|
|
},
|
|
|
|
raw_data::Intersection {
|
|
|
|
point: right,
|
|
|
|
elevation: 0.0 * si::M,
|
|
|
|
has_traffic_signal: false,
|
|
|
|
},
|
|
|
|
],
|
2018-08-23 20:19:09 +03:00
|
|
|
buildings: vec![
|
|
|
|
raw_data::Building {
|
|
|
|
points: north_pts,
|
|
|
|
osm_tags: BTreeMap::new(),
|
|
|
|
osm_way_id: 456,
|
|
|
|
},
|
|
|
|
raw_data::Building {
|
|
|
|
points: south_pts,
|
|
|
|
osm_tags: BTreeMap::new(),
|
|
|
|
osm_way_id: 789,
|
|
|
|
},
|
|
|
|
],
|
2018-08-18 20:08:28 +03:00
|
|
|
parcels: Vec::new(),
|
|
|
|
coordinates_in_world_space: true,
|
|
|
|
},
|
|
|
|
&map_model::Edits::new(),
|
|
|
|
);
|
|
|
|
|
|
|
|
assert_eq!(map.all_roads().len(), 1);
|
|
|
|
assert_eq!(
|
|
|
|
map.get_r(map_model::RoadID(0)).children_forwards,
|
|
|
|
vec![
|
|
|
|
(LaneID(0), LaneType::Driving),
|
|
|
|
(LaneID(1), LaneType::Parking),
|
|
|
|
(LaneID(2), LaneType::Sidewalk),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
assert_eq!(
|
|
|
|
map.get_r(map_model::RoadID(0)).children_backwards,
|
|
|
|
vec![
|
|
|
|
(LaneID(3), LaneType::Driving),
|
|
|
|
(LaneID(4), LaneType::Parking),
|
|
|
|
(LaneID(5), LaneType::Sidewalk),
|
|
|
|
]
|
|
|
|
);
|
|
|
|
map
|
|
|
|
}
|
2018-08-23 20:19:09 +03:00
|
|
|
|
|
|
|
fn triangle_around(x: f64, y: f64) -> Vec<geom::LonLat> {
|
|
|
|
vec![
|
|
|
|
geom::LonLat::new(x - 5.0, y - 5.0),
|
|
|
|
geom::LonLat::new(x + 5.0, y - 5.0),
|
|
|
|
geom::LonLat::new(x, y + 5.0),
|
|
|
|
]
|
|
|
|
}
|