GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-01-23T18:35:51Z,
for the dataset file:///shared/metra.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:
2026-01-12
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: 1
  • Blocks: 17
  • Routes: 10
  • Shapes: 24
  • Stops: 944
  • Trips: 278

Specification Compliance report

11125 notices reported (0 errors, 11122 warnings, 3 infos)

Notice Code Severity Total
equal_shape_distance_same_coordinates WARNING 11029

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.

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

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`.
"29219" 6697 6530.084617242548 58 6696 6530.084617242548 57
"29219" 6698 6530.084617242548 59 6697 6530.084617242548 58
"29219" 6699 6530.084617242548 60 6698 6530.084617242548 59
"29219" 6701 6629.923830432587 62 6700 6629.923830432587 61
"29219" 6702 6629.923830432587 63 6701 6629.923830432587 62
"29219" 6704 6652.407000222773 65 6703 6652.407000222773 64
"29219" 6705 6652.407000222773 66 6704 6652.407000222773 65
"29219" 6706 6652.407000222773 67 6705 6652.407000222773 66
"29219" 6708 6669.577010931394 69 6707 6669.577010931394 68
"29219" 6709 6669.577010931394 70 6708 6669.577010931394 69
"29219" 6710 6669.577010931394 71 6709 6669.577010931394 70
"29219" 6712 6685.850989085163 73 6711 6685.850989085163 72
"29219" 6713 6685.850989085163 74 6712 6685.850989085163 73
"29219" 6714 6685.850989085163 75 6713 6685.850989085163 74
"29219" 6716 6702.209414982603 77 6715 6702.209414982603 76
"29219" 6717 6702.209414982603 78 6716 6702.209414982603 77
"29219" 6718 6702.209414982603 79 6717 6702.209414982603 78
"29219" 6720 6718.452627053535 81 6719 6718.452627053535 80
"29219" 6721 6718.452627053535 82 6720 6718.452627053535 81
"29219" 6722 6718.452627053535 83 6721 6718.452627053535 82
"29219" 6724 6734.903607770319 85 6723 6734.903607770319 84
"29219" 6725 6734.903607770319 86 6724 6734.903607770319 85
"29219" 6726 6734.903607770319 87 6725 6734.903607770319 86
"29219" 6728 6751.160603074737 89 6727 6751.160603074737 88
"29219" 6729 6751.160603074737 90 6728 6751.160603074737 89
"29219" 6730 6751.160603074737 91 6729 6751.160603074737 90
"29219" 6732 6801.667880414873 93 6731 6801.667880414873 92
"29219" 6736 6870.07206650131 97 6735 6870.07206650131 96
"29219" 6737 6870.07206650131 98 6736 6870.07206650131 97
"29219" 6738 6870.07206650131 99 6737 6870.07206650131 98
"29219" 6740 6910.805853538955 101 6739 6910.805853538955 100
"29219" 6741 6910.805853538955 102 6740 6910.805853538955 101
"29219" 6742 6910.805853538955 103 6741 6910.805853538955 102
"29219" 6744 6916.001880162177 105 6743 6916.001880162177 104
"29219" 6745 6916.001880162177 106 6744 6916.001880162177 105
"29219" 6746 6916.001880162177 107 6745 6916.001880162177 106
"29219" 6752 7186.140456264802 113 6751 7186.140456264802 112
"29219" 6753 7186.140456264802 114 6752 7186.140456264802 113
"29219" 6754 7186.140456264802 115 6753 7186.140456264802 114
"29219" 6759 7380.263696822223 120 6758 7380.263696822223 119
"29219" 6760 7380.263696822223 121 6759 7380.263696822223 120
"29219" 6761 7380.263696822223 122 6760 7380.263696822223 121
"29219" 6766 7531.201685630575 127 6765 7531.201685630575 126
"29219" 6767 7531.201685630575 128 6766 7531.201685630575 127
"29219" 6768 7531.201685630575 129 6767 7531.201685630575 128
"29219" 6770 7570.2544036739355 131 6769 7570.2544036739355 130
"29219" 6771 7570.2544036739355 132 6770 7570.2544036739355 131
"29219" 6772 7570.2544036739355 133 6771 7570.2544036739355 132
"29219" 6774 7599.02545795472 135 6773 7599.02545795472 134
"29219" 6775 7599.02545795472 136 6774 7599.02545795472 135
leading_or_trailing_whitespaces WARNING 37

leading_or_trailing_whitespaces

The value in CSV file has leading or trailing whitespaces.

This notice is emitted for values protected with double quotes since whitespaces for non-protected values are trimmed automatically by CSV parser.

The validator strips whitespaces from protected values. We do not see any use case when such a whitespace may be needed. On the other hand, some real-world feeds use trailing whitespaces for some values and omit them for the others. This is causing the largest problem when a primary key and a foreign key differ just by a whitespace: it is clear that they are intended to be the same, that is why we always strip whitespaces.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"stops.txt" 6 "stop_name" "S Lumpkin Rd and Hawthorne Dr "
"stops.txt" 345 "stop_name" "S Lumpkin Rd and Custer Rd "
"stops.txt" 569 "stop_name" "Allied Dr and Joy Rd "
"stops.txt" 590 "stop_name" "Fort Benning Rd and Levy Rd "
"stops.txt" 800 "stop_name" "Victory Dr and S Lumpkin Rd "
"stops.txt" 832 "stop_name" "S Lumpkin Rd and Hendrix St "
"stops.txt" 833 "stop_name" "S Lumpkin Rd and Ormand St "
"stops.txt" 834 "stop_name" "S Lumpkin Rd and Plantation Rd "
"stops.txt" 835 "stop_name" "Torch Hill Rd and S Lumpkin Rd "
"stops.txt" 836 "stop_name" "Torch Hill Rd and Matheson Rd "
"stops.txt" 839 "stop_name" "Fort Benning Rd and Shelby St "
"stops.txt" 842 "stop_name" "Fort Benning Rd and Albion Way "
"stops.txt" 844 "stop_name" "Fort Benning Rd and Vine St "
"stops.txt" 845 "stop_name" "Fort Benning Rd and Baker Plaza Dr "
"stops.txt" 849 "stop_name" "Cusseta Rd and 32nd Ave "
"stops.txt" 850 "stop_name" "30th Ave and Cusseta Rd "
"stops.txt" 852 "stop_name" "N Lumpkin Rd and 32nd Ave "
"stops.txt" 853 "stop_name" "N Lumpkin Rd and Springfield Ave "
"stops.txt" 857 "stop_name" "Victory Dr and Clay Dr "
"stops.txt" 858 "stop_name" "Victory Dr and 30th Ave "
"stops.txt" 859 "stop_name" "30th Ave and Clarabelle St "
"stops.txt" 861 "stop_name" "Victory Dr and Airview Dr "
"stops.txt" 862 "stop_name" "Shepard Dr and 17th Ave "
"stops.txt" 865 "stop_name" "Shepard Dr and 17th Ave "
"stops.txt" 868 "stop_name" "Cusseta Rd and 30th Ave "
"stops.txt" 870 "stop_name" "2nd Ave and 10th St "
"stops.txt" 873 "stop_name" "Rigdon Rd and Fern St "
"stops.txt" 880 "stop_name" "2nd Ave and 13th St "
"stops.txt" 882 "stop_name" "2nd Ave and 11th St "
"stops.txt" 883 "stop_name" "2nd Ave and 8th St "
"stops.txt" 894 "stop_name" "Bradley Park Dr and Whitesville Rd "
"stops.txt" 907 "stop_name" "Macon Rd and Preston Dr "
"stops.txt" 910 "stop_name" "River Rd and Earline Ave "
"stops.txt" 912 "stop_name" "Victory Dr and 22nd Ave "
"routes.txt" 2 "route_long_name" "Route 1 "
"routes.txt" 6 "route_desc" " Route 5 serves 10th Ave, Talbotton Rd, 2nd Ave, Manchester Expy, College Dr, University Ave and Gentian Rd. In service from 5am to 7:20pm, Mon – Sat. Last trip departs the Transfer Center at 6pm."
"routes.txt" 10 "route_long_name" "Route 10 "
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 10

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`.
"5072" 2 "Route 1" "Route 1"
"5073" 3 "Route 2" "Route 2"
"5094" 4 "Route 3" "Route 3"
"5098" 5 "Route 4" "Route 4"
"5102" 6 "Route 5" "Route 5"
"5104" 7 "Route 6" "Route 6"
"5107" 8 "Route 7" "Route 7"
"5108" 9 "Route 9" "Route 9"
"5109" 10 "Route 10" "Route 10"
"5110" 11 "Route 12" "Route 12"
stop_without_stop_time WARNING 5

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.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
119 "6098737" "Fort Benning Rd and Baker Plaza Dr"
124 "6098742" "Fort Benning Rd and Chapman Way"
181 "6098826" "Buena Vista Rd and Annette Ave"
838 "6111567" "Fort Benning Rd and Victory Dr"
861 "6149851" "Victory Dr and Airview Dr"
trip_distance_exceeds_shape_distance_below_threshold WARNING 39

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.
"5202" "29220" 18106.055087867942 18106.05508786793 0.0
"5206" "29220" 18106.055087867942 18106.05508786793 0.0
"5210" "29220" 18106.055087867942 18106.05508786793 0.0
"5301" "29202" 26097.587878845843 26097.587878845803 0.0
"5303" "29202" 26097.587878845843 26097.587878845803 0.0
"5305" "29202" 26097.587878845843 26097.587878845803 0.0
"5307" "29202" 26097.587878845843 26097.587878845803 0.0
"5508" "29220" 18106.055087867942 18106.05508786793 0.0
"5801" "29202" 26097.587878845843 26097.587878845803 0.0
"5803" "29202" 26097.587878845843 26097.587878845803 0.0
"5805" "29202" 26097.587878845843 26097.587878845803 0.0
"5807" "29202" 26097.587878845843 26097.587878845803 0.0
"6001" "29197" 11915.732580171576 11915.722304788864 0.0
"6003" "29197" 11915.732580171576 11915.722304788864 0.0
"6005" "29197" 11915.732580171576 11915.722304788864 0.0
"6007" "29197" 11915.732580171576 11915.722304788864 0.0
"6009" "29197" 11915.732580171576 11915.722304788864 0.0
"6011" "29197" 11915.732580171576 11915.722304788864 0.0
"6013" "29197" 11915.732580171576 11915.722304788864 0.0
"6102" "29220" 18106.055087867942 18106.05508786793 0.0
"6106" "29220" 18106.055087867942 18106.05508786793 0.0
"6110" "29220" 18106.055087867942 18106.05508786793 0.0
"6704" "29220" 18106.055087867942 18106.05508786793 0.0
"6801" "29202" 26097.587878845843 26097.587878845803 0.0
"6803" "29202" 26097.587878845843 26097.587878845803 0.0
"6805" "29202" 26097.587878845843 26097.587878845803 0.0
"7101" "29197" 11915.732580171576 11915.722304788864 0.0
"7103" "29197" 11915.732580171576 11915.722304788864 0.0
"7105" "29197" 11915.732580171576 11915.722304788864 0.0
"7107" "29197" 11915.732580171576 11915.722304788864 0.0
"7109" "29197" 11915.732580171576 11915.722304788864 0.0
"7111" "29197" 11915.732580171576 11915.722304788864 0.0
"7202" "29220" 18106.055087867942 18106.05508786793 0.0
"7206" "29220" 18106.055087867942 18106.05508786793 0.0
"7301" "29202" 26097.587878845843 26097.587878845803 0.0
"7303" "29202" 26097.587878845843 26097.587878845803 0.0
"7305" "29202" 26097.587878845843 26097.587878845803 0.0
"7504" "29220" 18106.055087867942 18106.05508786793 0.0
"7508" "29220" 18106.055087867942 18106.05508786793 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"