GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-01-23T23:43:24Z,
for the dataset file:///shared/megabus-us.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Trillium Solutions, Inc.
Feed Email:
support+test+megabus-us@trilliumtransit.com
Feed Language:
English
Feed Start Date:
2025-11-06
Feed End Date:
2026-05-01

Files included


  1. agency.txt
  2. areas.txt
  3. booking_rules.txt
  4. calendar.txt
  5. calendar_attributes.txt
  6. calendar_dates.txt
  7. directions.txt
  8. fare_attributes.txt
  9. fare_rules.txt
  10. farezone_attributes.txt
  11. feed_info.txt
  12. frequencies.txt
  13. linked_datasets.txt
  14. location_groups.txt
  15. routes.txt
  16. runcut.txt
  17. shapes.txt
  18. stop_attributes.txt
  19. stop_times.txt
  20. stops.txt
  21. timetable_stop_order.txt
  22. timetables.txt
  23. transfers.txt
  24. trips.txt

Counts


  • Agencies: 10
  • Blocks: 0
  • Routes: 43
  • Shapes: 270
  • Stops: 999
  • Trips: 976

Specification Compliance report

442 notices reported (0 errors, 391 warnings, 51 infos)

Notice Code Severity Total
fast_travel_between_consecutive_stops WARNING 4

fast_travel_between_consecutive_stops

A transit vehicle moves too fast between two consecutive stops.

The speed threshold depends on route type:

Route type Description Threshold, km/h
0 Light rail 100
1 Subway 150
2 Rail 500
3 Bus 150
4 Ferry 80
5 Cable tram 30
6 Aerial lift 50
7 Funicular 50
11 Trolleybus 150
12 Monorail 150
- Unknown 200

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
530 "t_5808743_b_82027_tn_0" "15278" 186.53546821083543 6.217848940361181 3340 6 "2578176" "Rt 17 & Old Orange Tpk" "18:41:00" 3341 7 "2577698" "Metro North Station - Harriman" "18:42:00"
478 "t_5808918_b_82027_tn_0" "15274" 167.39581203968604 5.579860401322867 5382 7 "2577706" "Rt 17 & Prospect St" "12:06:00" 5383 8 "2577704" "Rt 17 & Lake St" "12:07:00"
647 "t_5808904_b_82027_tn_0" "15283" 198.71289397410698 36.430697228586276 5252 2 "2577762" "Ridgewood Park and Ride North" "10:32:00" 5253 3 "2577792" "Woodbury Common" "10:42:00"
643 "t_5808716_b_82027_tn_0" "15283" 183.24797716029926 18.324797716029927 2942 7 "2577837" "Rt 6 & I-84" "17:38:00" 2943 8 "2577836" "Dingmans Tpk & I-84 - Lords Valley" "17:43:00"
fast_travel_between_far_stops WARNING 2

fast_travel_between_far_stops

A transit vehicle moves too fast between two far stops.

Two stops are considered "far" if they are more than 10 km apart. This normally indicates a more serious problem than too fast travel between consecutive stops.

The speed threshold depends on route type and are the same as fast_travel_between_consecutive_stops.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
647 "t_5808904_b_82027_tn_0" "15283" 198.71289397410698 36.430697228586276 5252 2 "2577762" "Ridgewood Park and Ride North" "10:32:00" 5253 3 "2577792" "Woodbury Common" "10:42:00"
643 "t_5808716_b_82027_tn_0" "15283" 183.24797716029926 18.324797716029927 2942 7 "2577837" "Rt 6 & I-84" "17:38:00" 2943 8 "2577836" "Dingmans Tpk & I-84 - Lords Valley" "17:43:00"
mixed_case_recommended_field WARNING 6

mixed_case_recommended_field

This field has customer-facing text and should use Mixed Case (should contain upper and lower case letters).

This field contains customer-facing text and should use Mixed Case (upper and lower case letters) to ensure good readability when displayed to riders. Avoid the use of abbreviations throughout the feed (e.g. St. for Street) unless a location is called by its abbreviated name (e.g. “JFK Airport”). Abbreviations may be problematic for accessibility by screen reader software and voice user interfaces.

Good examples:
Field Text Dataset
"Schwerin, Hauptbahnhof" Verkehrsverbund Berlin-Brandenburg
"Red Hook/Atlantic Basin" NYC Ferry
"Campo Grande Norte" Carris
Bad examples:
Field Text
"GALLERIA MALL"
"3427 GG 17"
"21 Clark Rd Est"

You can see more about this notice here.

filename (?) Name of the faulty file. fieldName (?) Name of the faulty field. fieldValue (?) Faulty value. csvRowNumber (?) The row number of the faulty record.
"stops.txt" "stop_name" "63rd and 18th" 51
"stops.txt" "stop_name" "63rd and 18th" 58
"stops.txt" "stop_name" "54th and 8th" 65
"stops.txt" "stop_name" "63rd and 10th" 69
"stops.txt" "stop_name" "63rd and 14th" 70
"stops.txt" "stop_name" "63rd and 14th" 71
route_long_name_contains_short_name WARNING 1

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`.
"6182" 38 "Newark Airport Express" "Newark Airport Express"
route_short_name_too_long WARNING 41

route_short_name_too_long

Short name of a route is too long (more than 12 characters).

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`.
"15255" 2 "Community Coach"
"15246" 3 "Rockland Coaches"
"15253" 4 "Rockland Coaches"
"15251" 5 "Rockland Coaches"
"15249" 6 "Rockland Coaches"
"15248" 7 "Rockland Coaches"
"15247" 8 "Rockland Coaches"
"15301" 9 "Community Coach"
"15245" 10 "Rockland Coaches"
"15231" 11 "ShortLine Hudson"
"15277" 12 "ShortLine Hudson"
"15269" 13 "ShortLine Hudson"
"15232" 14 "ShortLine Hudson"
"15276" 15 "ShortLine Hudson"
"15281" 16 "ShortLine Hudson"
"15274" 17 "ShortLine Hudson"
"15278" 18 "ShortLine Hudson"
"15300" 19 "Community Coach"
"15279" 20 "ShortLine Hudson"
"15280" 21 "ShortLine Hudson"
"15283" 22 "ShortLine Hudson"
"15268" 23 "ShortLine Hudson"
"15272" 24 "ShortLine Hudson"
"15273" 25 "ShortLine Hudson"
"15649" 26 "ShortLine Hudson"
"15260" 28 "Suburban Transit"
"15261" 29 "Suburban Transit"
"15262" 30 "Suburban Transit"
"15263" 31 "Suburban Transit"
"15264" 32 "Suburban Transit"
"15265" 33 "Suburban Transit"
"15266" 34 "Suburban Transit"
"15267" 35 "Suburban Transit"
"15315" 36 "Suburban Transit"
"15259" 37 "Suburban Transit"
"6182" 38 "Newark Airport Express"
"4716" 40 "Wisconsin Coach Lines"
"4715" 41 "Wisconsin Coach Lines"
"33306" 42 "Waukesha County Transit"
"33305" 43 "Waukesha County Transit"
"33304" 44 "Waukesha County Transit"
stop_without_stop_time WARNING 337

stop_without_stop_time

A stop in stops.txt is not referenced by any stop_times.stop_id.

Such stops are not used by any trip and normally do not provide user value. This notice may indicate a typo in stop_times.txt.

You can see more about this notice here.

Only the first 50 of 337 affected records are displayed below.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
3 "2332494" "White Marsh MTA Park & Ride"
4 "2332499" "Buffalo Niagara International Airport"
6 "2332520" "St Catherines Union Bus Terminal"
7 "2332525" "St Paul Union Depot Bus"
8 "2332537" "1500 San Jacinto Blvd"
9 "2332549" "Buffalo Metropolitan Transportation Center"
10 "2332555" "GM&O Transit Center"
12 "2332560" "The Plaza at Main Street Station"
13 "2332561" "10th St and Penn Ave"
14 "2332563" "Irving 24 Service Center"
17 "2332586" "Downtown Riverside Metrolink"
18 "2332587" "Niagara Falls Bus Terminal"
19 "2332588" "DC Union Station"
21 "2332594" "State College Walmart"
22 "2332595" "Scarborough Town Center"
23 "2332605" "MATA Airways Transit Center"
24 "2332608" "Kingston Bus Terminal"
25 "2332617" "34th St between W 11th Ave and W 12th Ave"
26 "2332619" "Sheridan Street Tri-Rail Station"
27 "2332629" "Whitby GO Station"
28 "2332630" "Port Authority Bus Terminal"
29 "2332631" "Katy Mills Mall"
30 "2332637" "New Orleans Union Passenger Terminal"
31 "2332641" "997 St-Antoine Ouest - Métro Bonaventure"
33 "2332649" "Kirkland Depanneur Beausoir"
34 "2332654" "White Marsh Mall"
35 "2332661" "Miami Intermodal Center"
36 "2332662" "CATS Terminal"
37 "2332663" "Intermodal Transit Facility"
38 "2332680" "Main St & Christie St"
39 "2332684" "318 3rd Ave N"
40 "2332695" "Independence Hall Visitors Center"
42 "2332707" "Intercity Bus Terminal"
43 "2332713" "MAX Central Station"
44 "2384096" "Tanger Outlets - Daytona"
72 "2436307" "JMU Godwin Transit Center"
73 "2436455" "Martins Supermarket"
76 "2526378" "Durham Transportation Center"
77 "2576719" "Main St & Railroad Ave E"
78 "2576721" "N Main St & Elm St"
79 "2576722" "N Main St & Park Square"
80 "2576723" "Lils Deli S"
81 "2576724" "Lake Shore Rd & Amsdell Rd N"
82 "2576727" "Lake Shore Rd & Triangle Rd S"
83 "2576728" "Central Ave & Main Rd E"
84 "2576729" "Porter Rd & Webster Rd S"
85 "2576730" "4179 Lake Shore Rd"
86 "2576731" "Buffalo Airport - Metro Bus Area"
87 "2576733" "N Main Street Ext & Gerry Levant Rd N"
88 "2576734" "Erie Rd & Lotus Point Rd"
platform_without_parent_station INFO 9

platform_without_parent_station

A platform has no parent_station field set.

This is different from location_without_parent_station since it is less severe.

You can see more about this notice here.

csvRowNumber (?) Row number of the faulty record. stopId (?) The id of the faulty record. stopName (?) The stop name of the faulty record.
22 "2332595" "Scarborough Town Center"
23 "2332605" "MATA Airways Transit Center"
39 "2332684" "318 3rd Ave N"
42 "2332707" "Intercity Bus Terminal"
76 "2526378" "Durham Transportation Center"
112 "2576761" "Buffalo Amtrak"
836 "3453518" "Arrowood Light Rail Station"
905 "4160306" "GW Bridge Terminal"
922 "4211698" "ARTIC - Bus Bay #S3"
unknown_column INFO 34

unknown_column

A column name is unknown.

You can see more about this notice here.

filename (?) The name of the faulty file. fieldName (?) The name of the unknown column. index (?) The index of the faulty column.
"areas.txt" "wkt" 2
"agency.txt" "tts_agency_name" 8
"calendar.txt" "service_name" 2
"calendar_dates.txt" "holiday_name" 3
"feed_info.txt" "feed_license" 5
"feed_info.txt" "feed_id" 10
"routes.txt" "min_headway_minutes" 11
"routes.txt" "eligibility_restricted" 12
"routes.txt" "tts_route_short_name" 15
"routes.txt" "tts_route_long_name" 16
"stop_times.txt" "start_service_area_id" 11
"stop_times.txt" "end_service_area_id" 12
"stop_times.txt" "start_service_area_radius" 13
"stop_times.txt" "end_service_area_radius" 14
"stop_times.txt" "mean_duration_factor" 21
"stop_times.txt" "mean_duration_offset" 22
"stop_times.txt" "safe_duration_factor" 23
"stop_times.txt" "safe_duration_offset" 24
"stop_times.txt" "tts_stop_headsign" 25
"stop_times.txt" "min_arrival_time" 26
"stop_times.txt" "max_departure_time" 27
"stops.txt" "position" 13
"stops.txt" "direction" 14
"trips.txt" "trip_type" 11
"trips.txt" "drt_max_travel_time" 12
"trips.txt" "drt_avg_travel_time" 13
"trips.txt" "drt_advance_book_min" 14
"trips.txt" "drt_pickup_message" 15
"trips.txt" "drt_drop_off_message" 16
"trips.txt" "continuous_pickup_message" 17
"trips.txt" "continuous_drop_off_message" 18
"trips.txt" "tts_trip_headsign" 19
"trips.txt" "tts_trip_short_name" 20
"location_groups.txt" "location_id" 2
unknown_file INFO 8

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"calendar_attributes.txt"
"directions.txt"
"farezone_attributes.txt"
"runcut.txt"
"stop_attributes.txt"
"timetable_stop_order.txt"
"timetables.txt"
"linked_datasets.txt"