GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-01-23T18:25:37Z,
for the dataset file:///shared/mountain-metropolitan.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Mountain Metro Transit
Publisher URL:
http://www.mmtransit.com
Feed Email:
N/A
Feed Language:
English
Feed Start Date:
2025-04-27
Feed End Date:
2025-09-27

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. feed_info.txt
  5. routes.txt
  6. shapes.txt
  7. stop_times.txt
  8. stops.txt
  9. transfers.txt
  10. trips.txt

Counts


  • Agencies: 0
  • Blocks: 142
  • Routes: 34
  • Shapes: 72
  • Stops: 983
  • Trips: 4396

Specification Compliance report

1801 notices reported (0 errors, 1801 warnings, 0 infos)

Notice Code Severity Total
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 26

equal_shape_distance_diff_coordinates_distance_below_threshold

Two consecutive points have equal shape_dist_traveled and different lat/lon coordinates in shapes.txt and the distance between the two points is greater than 0 but less than 1.11m.

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 small difference of coordinates (greater than 0 but less than 1.11 m distance) result in a warning.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) The faulty record's `shape_dist_traveled` value. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) The previous shape point's `shape_dist_traveled` value. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`. actualDistanceBetweenShapePoints (?) Actual distance traveled along the shape from the first shape point to the previous shape point.
"10059" 10680 9.1404 198 10679 9.1404 197 0.2602043162115845
"10059" 10682 9.2184 200 10681 9.2184 199 0.6927498525899363
"10058" 10242 2.7207 93 10241 2.7207 92 0.6927498525899363
"10058" 10244 2.7988 95 10243 2.7988 94 0.2602043162115845
"10020" 184 7.4912 183 183 7.4912 182 0.3420476570027795
"10020" 186 7.5065 185 185 7.5065 184 0.7783657084907514
"10064" 11907 5.1616 89 11906 5.1616 88 0.14099331623768768
"10064" 11909 5.1769 91 11908 5.1769 90 0.4334388978485649
"10029" 2607 9.4069 213 2606 9.4069 212 0.20572330886814816
"10029" 2609 9.42 215 2608 9.42 214 0.8228922605300776
"10022" 588 2.4438 66 587 2.4438 65 0.728360696999981
"10022" 590 2.447 68 589 2.447 67 0.23869192684039625
"10065" 12075 3.6616 91 12074 3.6616 90 0.4334388978485649
"10065" 12077 3.6769 93 12076 3.6769 92 0.14099331623768768
"10023" 1027 8.8751 223 1026 8.8751 222 0.23869192684039625
"10023" 1029 8.8783 225 1028 8.8783 224 0.728360696999981
"10028" 2173 1.1022 32 2172 1.1022 31 0.8228922605300776
"10028" 2175 1.1153 34 2174 1.1153 33 0.20572330886814816
"10031" 2935 2.0248 49 2934 2.0248 48 0.6893021633182113
"10031" 2937 2.0798 51 2936 2.0798 50 0.5626846193539577
"10030" 2853 8.1871 220 2852 8.1871 219 0.5626846193539577
"10030" 2855 8.2421 222 2854 8.2421 221 0.6893021633182113
"10033" 3771 9.9508 280 3770 9.9508 279 0.333585304144125
"10033" 3773 10.1151 282 3772 10.1151 281 0.3446424006467834
"10032" 3212 1.039 24 3211 1.039 23 0.3446424006467834
"10032" 3214 1.2033 26 3213 1.2033 25 0.333585304144125
expired_calendar WARNING 3

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.
2 "87.0.1"
3 "87.0.2"
4 "87.0.3"
feed_expiration_date7_days WARNING 1

feed_expiration_date7_days

Dataset should be valid for at least the next 7 days.

The dataset expiration date defined in feed_info.txt is in seven days or less. At any time, the published GTFS dataset should be valid for at least the next 7 days.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. currentDate (?) Current date (YYYYMMDD format). feedEndDate (?) Feed end date (YYYYMMDD format). suggestedExpirationDate (?) Suggested expiration date (YYYYMMDD format).
2 "20260123" "20250927" "20260130"
missing_feed_contact_email_and_url WARNING 1

missing_feed_contact_email_and_url

Best Practices for feed_info.txt suggest providing at least one of feed_contact_email and feed_contact_url.

You can see more about this notice here.

csvRowNumber (?) The row number of the validated record.
2
missing_recommended_field WARNING 35

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.
"agency.txt" 2 "agency_id"
"routes.txt" 2 "agency_id"
"routes.txt" 3 "agency_id"
"routes.txt" 4 "agency_id"
"routes.txt" 5 "agency_id"
"routes.txt" 6 "agency_id"
"routes.txt" 7 "agency_id"
"routes.txt" 8 "agency_id"
"routes.txt" 9 "agency_id"
"routes.txt" 10 "agency_id"
"routes.txt" 11 "agency_id"
"routes.txt" 12 "agency_id"
"routes.txt" 13 "agency_id"
"routes.txt" 14 "agency_id"
"routes.txt" 15 "agency_id"
"routes.txt" 16 "agency_id"
"routes.txt" 17 "agency_id"
"routes.txt" 18 "agency_id"
"routes.txt" 19 "agency_id"
"routes.txt" 20 "agency_id"
"routes.txt" 21 "agency_id"
"routes.txt" 22 "agency_id"
"routes.txt" 23 "agency_id"
"routes.txt" 24 "agency_id"
"routes.txt" 25 "agency_id"
"routes.txt" 26 "agency_id"
"routes.txt" 27 "agency_id"
"routes.txt" 28 "agency_id"
"routes.txt" 29 "agency_id"
"routes.txt" 30 "agency_id"
"routes.txt" 31 "agency_id"
"routes.txt" 32 "agency_id"
"routes.txt" 33 "agency_id"
"routes.txt" 34 "agency_id"
"routes.txt" 35 "agency_id"
mixed_case_recommended_field WARNING 1711

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.

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

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" "735 19th" 9
"stops.txt" "stop_name" "1747 S 8th" 132
"stops.txt" "stop_name" "COLORADO/PIKES PEAK" 288
"stops.txt" "stop_name" "4575 CENTENNIAL BLVD" 464
"stops.txt" "stop_name" "CARMEL/CAPULIN" 544
"stops.txt" "stop_name" "935 N 19th" 576
"stops.txt" "stop_name" "914 N 19th" 586
"stops.txt" "stop_name" "NEW LIFE DR/ VOYAGER" 806
"stops.txt" "stop_name" "BRIARGATE/ UNION" 817
"stops.txt" "stop_name" "TUTT/1ST MAIN TOWN CENTER" 821
"stops.txt" "stop_name" "229 SECURITY BLVD" 844
"stops.txt" "stop_name" "2739 LAS VEGAS" 847
"stops.txt" "stop_name" "EL PASO/BECKERS" 866
"stops.txt" "stop_name" "MANITOU/SMISCHNY LOT WB 2406" 867
"stops.txt" "stop_name" "CITADEL CORE STOP" 949
"stops.txt" "stop_name" "BARNES/INTEGRITY CENTER POINT" 950
"stops.txt" "stop_name" "PPSC RAMPART" 951
"stops.txt" "stop_name" "BARNES/INTEGRITY CENTER POINT" 952
"stops.txt" "stop_name" "CENTENNIAL/ VAN BUREN NB" 974
"stops.txt" "stop_name" "CENTENNIAL/ VAN BUREN SB" 975
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 2
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 3
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 4
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 5
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 6
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 7
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 8
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 9
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 10
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 11
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 12
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 13
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 14
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 15
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 16
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 17
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 18
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 19
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 20
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 21
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 22
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 23
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 24
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 25
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 26
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 27
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 28
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 29
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 30
"trips.txt" "trip_headsign" "ARRIVING DOWNTOWN" 31
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`.
"3586" 35 "ZEB" "ZEB Downtown Shuttle"
same_name_and_description_for_stop WARNING 1

same_name_and_description_for_stop

Same name and description for stop.

The GTFS spec defines stops.txt stop_description as:

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

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty record. stopDesc (?) The faulty record's `stop_desc`.
562 "1326" "2150 GARDEN OF THE GODS"
stop_too_far_from_shape_using_user_distance WARNING 21

stop_too_far_from_shape_using_user_distance

Stop time too far from shape.

A stop time entry that is a large distance away from the location of the shape in shapes.txt as defined by shape_dist_traveled values.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the faulty record from `trips.txt`. shapeId (?) The id of the shape that is referred to. tripId (?) The id of the trip that is referred to. stopTimeCsvRowNumber (?) The row number of the faulty record from `stop_times.txt`. stopId (?) The id of the stop that is referred to. stopName (?) The name of the stop that is referred to. match (?) Latitude and longitude pair of the location. geoDistanceToShape (?) Distance from stop to shape.
377 "10035" "183356" 9999 "560" "Wahsatch/Cache La Poudre" [38.846382052757804,-104.81882296704642] 145.78106609234374
377 "10035" "183356" 10000 "2452" "Uintah/Nevada" [38.85021304038047,-104.81710301665133] 302.25103357720707
377 "10035" "183356" 10001 "2490" "Uintah/Cooper" [38.85090631844184,-104.83130133831818] 330.6882275218267
377 "10035" "183356" 10002 "16" "735 19th" [38.847929120843126,-104.84772891380065] 224.99618848530386
377 "10035" "183356" 10003 "1439" "935 N 19th" [38.84908712500046,-104.84991153435512] 322.35282677772165
377 "10035" "183356" 10004 "1440" "19th/Koshare" [38.85226528089888,-104.84973000000001] 323.1866456715447
377 "10035" "183356" 10005 "1441" "King/Tonka" [38.8550126,-104.84971900000001] 238.79777500534934
377 "10035" "183356" 10006 "1442" "King/Friendship" [38.85671556843843,-104.85014812160779] 321.0871272705941
377 "10035" "183356" 10007 "1443" "King/25th" [38.85628075157943,-104.85283789444918] 314.480749395049
377 "10035" "183356" 10008 "1444" "King/Pioneer" [38.85565723849893,-104.85649554756453] 327.9160455436743
377 "10035" "183356" 10009 "1445" "King/30th" [38.8556736513328,-104.86184446049978] 291.7614041397081
377 "10035" "183356" 10010 "1446" "Fontanero/30th" [38.85858809976331,-104.86461805697377] 245.527289061133
377 "10035" "183356" 10011 "1448" "902 Fontmore" [38.863780131673465,-104.86366166189731] 320.4963472525474
377 "10035" "183356" 10012 "1" "Fontmore/Mesa" [38.86720858741869,-104.86333082520315] 323.19803384087754
377 "10035" "183356" 10013 "2468" "W Fillmore/Grand Vista" [38.87009951466373,-104.85845100031156] 324.5692201766755
377 "10035" "183356" 10014 "2440" "Fillmore/Centennial" [38.8758998668342,-104.85001739324123] 327.92823646340736
377 "10035" "183356" 10015 "2469" "Fillmore/Chestnut" [38.87633853003885,-104.8418042784047] 327.7050787860484
377 "10035" "183356" 10016 "2470" "Fillmore/Wood" [38.875752333354185,-104.82874666663227] 323.3651635025993
377 "10035" "183356" 10017 "842" "Cascade/Taylor" [38.87432790416676,-104.82141620833931] 132.07755362778911
496 "10042" "183595" 11978 "1135" "Centennial/Pinon Valley OB" [38.90227481463926,-104.8554799773036] 288.66055849843167
2355 "10044" "183625" 43233 "159" "Southgate/Nevada" [38.806319,-104.821409] 123.01842569055955
trip_coverage_not_active_for_next7_days WARNING 1

trip_coverage_not_active_for_next7_days

Trips data should be valid for at least the next seven days.

This notice is triggered if the date range where a significant number of trips are running ends in less than 7 days.

You can see more about this notice here.

currentDate (?) Current date (YYYYMMDD format). serviceWindowStartDate (?) The start date of the majority service window. serviceWindowEndDate (?) The end date of the majority service window.
"20260123" "20250428" "20250926"