use transit_grid::prelude::TransitEdge;
pub type RailwayEdge = TransitEdge<f64>;
#[cfg(test)]
mod tests {
use super::*;
use geo::{coord, LineString};
use transit_grid::core::PathCoordinates;
#[test]
fn test_railway_edge_creation() {
let edge = RailwayEdge {
id: 1,
length: 1500.0,
path: LineString::from(vec![
coord! { x: 8.6821, y: 50.1109 },
coord! { x: 8.6921, y: 50.1209 },
]),
source: 0,
target: 0,
};
assert_eq!(edge.id, 1);
assert_eq!(edge.length, 1500.0);
}
#[test]
fn test_railway_edge_comparison() {
let edge1 = RailwayEdge {
id: 1,
length: 1500.0,
path: LineString::from(vec![
coord! { x: 8.6821, y: 50.1109 },
coord! { x: 8.6921, y: 50.1209 },
]),
source: 0,
target: 0,
};
let edge2 = RailwayEdge {
id: 1,
length: 1500.0,
path: LineString::from(vec![
coord! { x: 8.6821, y: 50.1109 },
coord! { x: 8.6921, y: 50.1209 },
]),
source: 0,
target: 0,
};
let edge3 = RailwayEdge {
id: 2,
length: 2500.0,
path: LineString::from(vec![
coord! { x: 8.6921, y: 50.1209 },
coord! { x: 8.7021, y: 50.1309 },
]),
source: 0,
target: 0,
};
assert_eq!(edge1, edge2);
assert_ne!(edge1, edge3);
}
#[test]
fn test_source_coordinate() {
let edge = RailwayEdge {
id: 1,
length: 1500.0,
path: LineString::from(vec![
coord! { x: 8.6821, y: 50.1109 },
coord! { x: 8.6921, y: 50.1209 },
]),
source: 0,
target: 0,
};
let source_coord = edge.source_coordinate();
assert_eq!(source_coord, coord! { x: 8.6821, y: 50.1109 });
}
#[test]
fn test_target_coordinate() {
let edge = RailwayEdge {
id: 1,
length: 1500.0,
path: LineString::from(vec![
coord! { x: 8.6821, y: 50.1109 },
coord! { x: 8.6921, y: 50.1209 },
]),
source: 0,
target: 0,
};
let target_coord = edge.target_coordinate();
assert_eq!(target_coord, coord! { x: 8.6921, y: 50.1209 });
}
}