GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-05-04T16:43:54Z,
for the dataset file:///shared/ridestreamline_4c34d8bc.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
GMV Syncromatics
Feed Email:
support@gmvsync.com
Feed Language:
English
Feed Start Date:
2025-11-25
Feed End Date:
N/A

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_attributes.txt
  4. calendar_dates.txt
  5. directions.txt
  6. feed_info.txt
  7. realtime_routes.txt
  8. routes.txt
  9. shapes.txt
  10. stop_times.txt
  11. stops.txt
  12. trips.txt

Counts


  • Agencies: 0
  • Blocks: 43
  • Routes: 7
  • Shapes: 19
  • Stops: 164
  • Trips: 409

Specification Compliance report

70 notices reported (14 errors, 53 warnings, 3 infos)

Notice Code Severity Total
block_trips_with_overlapping_stop_times ERROR 1

block_trips_with_overlapping_stop_times

Trips with the same block id have overlapping stop times.

You can see more about this notice here.

csvRowNumberA (?) The row number from `trips.txt` of the first faulty trip. tripIdA (?) The id of first faulty trip. serviceIdA (?) The service id of the first faulty trip. csvRowNumberB (?) The row number from `trips.txt` of the second faulty trip. tripIdB (?) The id of the other faulty trip. serviceIdB (?) The service id of the other faulty trip. blockId (?) The `trips.block_id` of the overlapping trip. intersection (?) The overlapping period.
135 "FQ-AM-1-4-3" "3" 138 "FQ-AM-1-5-3" "3" "509614" "20260511"
decreasing_or_equal_stop_time_distance ERROR 8

decreasing_or_equal_stop_time_distance

Decreasing or equal shape_dist_traveled in stop_times.txt.

When sorted by stop_times.stop_sequence, two consecutive entries in stop_times.txt should have increasing distance, based on the field shape_dist_traveled. If the values are equal, this is considered as an error.

You can see more about this notice here.

tripId (?) The id of the faulty trip. stopId (?) The id of the faulty stop. csvRowNumber (?) The row number from `stop_times.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. stopSequence (?) The faulty record's `stop_times.stop_sequence`. prevCsvRowNumber (?) The row number from `stop_times.txt` of the previous stop time. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous stop time. prevStopSequence (?) The previous record's `stop_times.stop_sequence`.
"WKND-R1-7-4" "11235824" 6275 0.0 1 6274 0.0 0
"FQ-AM-1-5-3" "11239335" 3440 2136.7756957543634 0 3438 2136.7756957543634 0
"FQ-AM-1-5-3" "11234877" 3441 5018.170147574442 1 3439 5018.170147574442 1
"WKND-R1-16-4" "11235824" 5767 0.0 1 5766 0.0 0
"WKND-R1-25-4" "11235824" 6085 0.0 1 6084 0.0 0
"WKND-R1-25" "11235824" 6071 0.0 1 6070 0.0 0
"WKND-R1-16" "11235824" 5753 0.0 1 5752 0.0 0
"WKND-R1-7" "11235824" 6261 0.0 1 6260 0.0 0
duplicate_key ERROR 3

duplicate_key

Duplicated entity.

The values of the given key and rows are duplicates.

You can see more about this notice here.

filename (?) The name of the faulty file oldCsvRowNumber (?) The row of the first occurrence. newCsvRowNumber (?) The row of the other occurrence. fieldName1 (?) Composite key's first field name. fieldValue1 (?) Composite key's first value.
"trips.txt" 137 138 "trip_id" "FQ-AM-1-5-3"
"stop_times.txt" 3438 3440 "trip_id,stop_sequence" "FQ-AM-1-5-3,0"
"stop_times.txt" 3439 3441 "trip_id,stop_sequence" "FQ-AM-1-5-3,1"
missing_required_field ERROR 1

missing_required_field

A required field is missing.

The given field has no value in some input row, even though values are required.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"agency.txt" 2 "agency_url"
stop_time_with_arrival_before_previous_departure_time ERROR 1

stop_time_with_arrival_before_previous_departure_time

Backwards time travel between stops in stop_times.txt

For a given trip_id, the arrival_time of (n+1)-th stoptime in sequence must not precede the departure_time of n-th stoptime in sequence in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. prevCsvRowNumber (?) The row of the previous stop time. tripId (?) The trip_id associated to the faulty record. arrivalTime (?) Arrival time at the faulty record. departureTime (?) Departure time at the previous stop time.
3439 3440 "FQ-AM-1-5-3" "08:45:00" "09:15:00"
equal_shape_distance_same_coordinates WARNING 2

equal_shape_distance_same_coordinates

Two consecutive points have equal shape_dist_traveled and the same lat/lon coordinates in shapes.txt.

When sorted by shape.shape_pt_sequence, the values for shape_dist_traveled must increase along a shape. Two consecutive points with equal values for shape_dist_traveled and the same coordinates indicate a duplicative shape point.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous shape point. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`.
"28767" 394 7452.071134903043 69 393 7452.071134903043 68
"28766" 324 11738.296218728105 147 323 11738.296218728105 146
expired_calendar WARNING 1

expired_calendar

Dataset should not contain date ranges for services that have already expired.

This warning takes into account the calendar_dates.txt file as well as the calendar.txt file.

You can see more about this notice here.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
3 "2"
missing_feed_info_date WARNING 1

missing_feed_info_date

One of feed_start_date or feed_end_date is specified, but not both.

Even though feed_info.start_date and feed_info.end_date are optional, if one field is provided the second one should also be provided.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. fieldName (?) Either `feed_end_date` or `feed_start_date`.
2 "feed_end_date"
missing_recommended_field WARNING 1

missing_recommended_field

A recommended field is missing.

The given field has no value in some input row, even though values are recommended.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"feed_info.txt" 2 "feed_end_date"
route_long_name_contains_short_name WARNING 5

route_long_name_contains_short_name

Long name should not contain short name for a single route.

In routes.txt, route_long_name should not contain the value for route_short_name, because when both are provided, they are often combined by transit applications. Note that only one of the two fields is required. If there is no short name used for a route, use route_long_name only.

Good examples:

route_short_name/route_long_name Dataset
"N"/"Judah" Muni San Fransisco
"6"/"ML King Jr Blvd" Trimet Portland Streetcar
"55"/"Boulevard Saint Laurent" STM Montreal
"1"/"Rangiora/Cashmere" Metro Christchurch

Bad examples:

route_short_name/route_long_name
"604"/"604"
"14"/"Route 14"
"2"/"Route 2: Bellows Falls In-Town"

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeShortName (?) The faulty record's `route_short_name`. routeLongName (?) The faulty record's `route_long_name`.
"6850" 2 "Blueline" "Blueline"
"6851" 3 "Livingston" "Livingston Seasonal"
"6852" 4 "Purpleline" "Purpleline"
"6854" 6 "Brownline" "Brownline"
"6855" 7 "Pinkline" "Pinkline"
same_name_and_description_for_route WARNING 1

same_name_and_description_for_route

Same name and description for route.

The GTFS spec defines routes.txt route_desc as:

Description of a route that provides useful, quality information. Do not simply duplicate the name of the route.

See the GTFS and GTFS Best Practices links below for more examples of how to populate the route_short_name, route_long_name, and route_desc fields.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. routeId (?) The id of the faulty record. routeDesc (?) The `routes.routes_desc` of the faulty record. specifiedField (?) Either `route_short_name` or `route_long_name`.
8 "6856" "Northeast Bozeman Shuttle" "route_long_name"
trip_distance_exceeds_shape_distance_below_threshold WARNING 42

trip_distance_exceeds_shape_distance_below_threshold

The distance between the last shape point and last stop point is greater than 0 but less than the 11.1m threshold.

You can see more about this notice here.

tripId (?) The faulty record's trip id. shapeId (?) The faulty record's shape id. maxTripDistanceTraveled (?) The faulty record's trip max distance traveled. maxShapeDistanceTraveled (?) The faulty record's shape max distance traveled. geoDistanceToShape (?) The distance in meters between the shape and the stop.
"BROWN-C-2" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-C-2-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-C-4" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-C-4-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-C-6" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-C-6-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-10" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-10-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-12" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-12-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-14" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-14-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-16" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-16-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-2" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-2-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-4" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-4-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-6" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-6-3" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-8" "28778" 7880.453381593752 7875.118334478388 0.0
"BROWN-E-8-3" "28778" 7880.453381593752 7875.118334478388 0.0
"PURPLE-C-1" "28785" 2881.83247158824 2876.6423560218295 0.0
"PURPLE-C-1-3" "28785" 2881.83247158824 2876.6423560218295 0.0
"WKND-R1-12" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R1-12-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R1-21" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R1-21-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R1-3" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R1-3-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-15" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-15-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-24" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-24-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-6" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R2-6-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-1" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-1-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-10" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-10-4" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-19" "28778" 7880.453381593752 7875.118334478388 0.0
"WKND-R3-19-4" "28778" 7880.453381593752 7875.118334478388 0.0
unknown_file INFO 3

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"calendar_attributes.txt"
"realtime_routes.txt"
"directions.txt"