diff --git a/pom.xml b/pom.xml
index 0201ae46565..3d07ed94fa7 100644
--- a/pom.xml
+++ b/pom.xml
@@ -982,7 +982,7 @@
org.opentripplanner
otp-client
- 0.0.16
+ 0.0.20
test
diff --git a/smoke-tests/Makefile b/smoke-tests/Makefile
index adc5ea8fbcd..9a2a1df965e 100644
--- a/smoke-tests/Makefile
+++ b/smoke-tests/Makefile
@@ -19,7 +19,7 @@ portland/osm.pbf:
${CURL} http://osm.ibi-transit.com/vex/45.424388,-122.885443,45.684746,-122.44084.pbf -o $@
seattle/osm.pbf:
- ${CURL} http://osm.ibi-transit.com/vex/47.481002,-122.459681,47.734124,-122.224433.pbf -o $@
+ ${CURL} http://osm.ibi-transit.com/vex/47.50925,-122.47458,47.786105,-122.224433.pbf -o $@
build-%: otp.jar %/osm.pbf
java -Xmx6G -jar otp.jar --build --save $*
diff --git a/smoke-tests/seattle/build-config.json b/smoke-tests/seattle/build-config.json
index 7ae045caa8d..fed9ca170ad 100644
--- a/smoke-tests/seattle/build-config.json
+++ b/smoke-tests/seattle/build-config.json
@@ -12,6 +12,11 @@
"feedId" : "volunteer",
"source" : "https://data.trilliumtransit.com/gtfs/soundgenerations-wa-us/soundgenerations-wa-us-volunteer--flex-v2.zip"
},
+ {
+ "type" : "gtfs",
+ "feedId" : "ccsww-nw",
+ "source" : "https://data.trilliumtransit.com/gtfs/catholiccommunity-wa-us/catholiccommunity-wa-us-northwest--flex-v2.zip"
+ },
{
"type" : "gtfs",
"feedId" : "payyourpal",
diff --git a/src/test/java/org/opentripplanner/smoketest/SeattleSmokeTest.java b/src/test/java/org/opentripplanner/smoketest/SeattleSmokeTest.java
index 75c771d5b0c..a47e0265121 100644
--- a/src/test/java/org/opentripplanner/smoketest/SeattleSmokeTest.java
+++ b/src/test/java/org/opentripplanner/smoketest/SeattleSmokeTest.java
@@ -16,6 +16,7 @@
import org.junit.jupiter.api.Tag;
import org.junit.jupiter.api.Test;
import org.opentripplanner.client.model.Coordinate;
+import org.opentripplanner.client.model.LegMode;
import org.opentripplanner.client.model.Route;
import org.opentripplanner.smoketest.util.SmokeTestRequest;
@@ -23,12 +24,15 @@
@Tag("seattle")
public class SeattleSmokeTest {
+ private static final String CCSWW_ROUTE = "Volunteer Services: Northwest";
Coordinate sodo = new Coordinate(47.5811, -122.3290);
Coordinate clydeHill = new Coordinate(47.6316, -122.2173);
- Coordinate boeingCreekPark = new Coordinate(47.755872, -122.361645);
Coordinate ronaldBogPark = new Coordinate(47.75601664, -122.33141);
+ Coordinate esperance = new Coordinate(47.7957, -122.3470);
+ Coordinate shoreline = new Coordinate(47.7568, -122.3483);
+
@Test
public void acrossTheCity() {
var modes = Set.of(TRANSIT, WALK);
@@ -43,14 +47,44 @@ public void acrossTheCity() {
@Test
public void flexAndTransit() {
var modes = Set.of(WALK, BUS, FLEX_DIRECT, FLEX_EGRESS, FLEX_ACCESS);
- SmokeTest.basicRouteTest(
- new SmokeTestRequest(boeingCreekPark, ronaldBogPark, modes),
+ SmokeTest.basicRouteTest(new SmokeTestRequest(shoreline, ronaldBogPark, modes), List.of("BUS"));
+ }
+
+ @Test
+ public void ccswwIntoKingCounty() {
+ var modes = Set.of(WALK, FLEX_DIRECT);
+ var plan = SmokeTest.basicRouteTest(
+ new SmokeTestRequest(esperance, shoreline, modes),
List.of("BUS")
);
+ var itin = plan.itineraries().get(0);
+ var flexLeg = itin.transitLegs().get(0);
+ assertEquals(CCSWW_ROUTE, flexLeg.route().name());
+ assertEquals(CCSWW_ROUTE, flexLeg.route().agency().name());
+ }
+
+ @Test
+ public void ccswwIntoSnohomishCounty() {
+ var modes = Set.of(WALK, FLEX_DIRECT);
+ var plan = SmokeTest.basicRouteTest(
+ new SmokeTestRequest(shoreline, esperance, modes),
+ List.of("BUS", "WALK")
+ );
+ var walkAndFlex = plan
+ .transitItineraries()
+ .stream()
+ .filter(i -> i.transitLegs().stream().anyMatch(l -> l.route().name().equals(CCSWW_ROUTE)))
+ .findFirst()
+ .get();
+ assertEquals(2, walkAndFlex.legs().size());
+ // walk to the border of King County
+ assertEquals(LegMode.WALK, walkAndFlex.legs().get(0).mode());
+ // and take flex inside Snohomish County to the destination
+ assertEquals(LegMode.BUS, walkAndFlex.legs().get(1).mode());
}
@Test
- public void monorailRoute() throws IOException, InterruptedException {
+ public void monorailRoute() throws IOException {
Set