-
Notifications
You must be signed in to change notification settings - Fork 1.1k
Add a "canceled" field to Place in GTFS GraphQL API #6445
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
base: dev-2.x
Are you sure you want to change the base?
Add a "canceled" field to Place in GTFS GraphQL API #6445
Conversation
Codecov Report❌ Patch coverage is Additional details and impacted files@@ Coverage Diff @@
## dev-2.x #6445 +/- ##
==========================================
Coverage 72.14% 72.14%
- Complexity 19673 19678 +5
==========================================
Files 2127 2127
Lines 79562 79570 +8
Branches 8041 8047 +6
==========================================
+ Hits 57397 57403 +6
Misses 19331 19331
- Partials 2834 2836 +2 ☔ View full report in Codecov by Sentry. 🚀 New features to boost your workflow:
|
Perhaps LegTime would be a more fitting place for this information rather than directly on Place. The reason is that in theory, departure from a stop might be canceled while arrival is still scheduled because the last stop(s) of the trip are canceled. Also, maybe we should differentiate between "planned cancellations" and "real-time cancellations". For that, there are two options: either make the boolean field's name more specific or some sort of an enum. I think we have previously identified some issues with trying to combine too many things into one enum as a trip might be both added and cancelled, for example. So maybe I'm leaning towards a boolean field called We could discuss this in a dev meeting next week. |
GTFS does not support planned cancellations and I have no idea how it works internally with Transmodel. Also, I don't think that it is possible to cancel the arrival but not departure even if the trip is terminated short in the current model. |
We decided to do a bigger refactoring after 2.7. For now, the pickup/dropoff statuses can be used to interpret that a stop is cancelled/skipped. We are parking this pr for now. |
# Conflicts: # application/src/test/java/org/opentripplanner/model/plan/ScheduledTransitLegTest.java
Release 2.7.0
# Conflicts: # application/src/main/java/org/opentripplanner/apis/gtfs/datafetchers/LegImpl.java # application/src/main/java/org/opentripplanner/model/plan/leg/FrequencyTransitLeg.java # application/src/test/java/org/opentripplanner/model/plan/ScheduledTransitLegTest.java
# Conflicts: # application/src/main/resources/org/opentripplanner/apis/gtfs/schema.graphqls
Summary
This adds a
canceled
field intoPlace
in GTFS GraphQL API, which is referenced inLeg
.It allows clients to show to the rider that if the boarding call, alighting call, or any of the intermediate calls are canceled.
It is possible to see if the boarding call or alighting call is canceled now indirectly by using
pickupType
anddropoffType
inLeg
(if the leg is a transit leg and it is null, it means that the call is canceled, but this is not documented at the API level and is only inferred by reading the code), but not intermediate calls.Issue
#6441
Unit tests
I have added a unit test for intermediate calls.
Documentation
Added in GraphQL