GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-05-04T09:35:31Z,
for the dataset file:///shared/chapel-hill-transit_0c3bb762.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-03
Feed End Date:
2026-08-09

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: 225
  • Routes: 23
  • Shapes: 44
  • Stops: 545
  • Trips: 3852

Specification Compliance report

1343 notices reported (0 errors, 1340 warnings, 3 infos)

Notice Code Severity Total
equal_shape_distance_same_coordinates WARNING 12

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`.
"21267" 1023 5407.704252981715 256 1022 5407.704252981715 255
"21320" 4304 6141.710863830632 434 4303 6141.710863830632 433
"27844" 16510 5686.262341253129 240 16509 5686.262341253129 239
"22135" 6972 5336.9972577472445 230 6971 5336.9972577472445 229
"22135" 7220 9672.733404251116 478 7219 9672.733404251116 477
"27847" 17573 254.28313583672093 15 17572 254.28313583672093 14
"21326" 4926 4196.373149124503 173 4925 4196.373149124503 172
"21326" 4988 5344.068272571935 235 4987 5344.068272571935 234
"21326" 5234 9669.948288848818 481 5233 9669.948288848818 480
"29189" 19058 4364.295792158457 196 19057 4364.295792158457 195
"27839" 15319 5562.989890469879 258 15318 5562.989890469879 257
"29339" 20371 10569.592206665766 541 20370 10569.592206665766 540
leading_or_trailing_whitespaces WARNING 1

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.
"routes.txt" 9 "route_long_name" "G - Booker Creek / UNC Hospitals "
route_long_name_contains_short_name WARNING 23

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`.
"6026" 2 "N" "N - Estes Park / UNC Hospitals / Meadowmont"
"6027" 3 "S" "S - UNC / Campus Friday Center South Park and Ride"
"6028" 4 "D" "D - UNC Hospitals / Franklin St / Old Durham Rd"
"6029" 5 "420" "420 - Hillsborough-Chapel Hill"
"6030" 6 "CM" "CM - Carrboro / Merritt Mill Rd"
"6032" 7 "HS" "HS - Morris Grove Elementary / Smith Level Rd"
"6033" 8 "NS" "NS - Eubanks Rd / Southern Village"
"6034" 9 "G" "G - Booker Creek / UNC Hospitals"
"6035" 10 "JFX" "JFX - Jones Ferry Road Express"
"6036" 11 "J" "J - Carrboro / Downtown Chapel Hill / Jones Ferry Rd"
"6045" 12 "A" "A - Martin Luther King Jr. Blvd / Northside / University Place"
"6046" 13 "B" "B - Baity Hill / UNC Hospitals"
"6047" 14 "CCX" "CCX - Chatham County Express"
"6048" 15 "CL" "CL - Sage / Old Oxford Rd / UNC Hospitals"
"6049" 16 "CW" "CW - Carrboro / Weaver Street / UNC"
"6050" 17 "F" "F - Colony Woods / Franklin St"
"6051" 18 "FCX" "FCX - Friday Center Express"
"6052" 19 "NU" "NU - RR Lot / UNC Hospitals"
"6053" 20 "RU" "RU - Campus Reverse Shuttle"
"6056" 21 "T" "T - MLK, Jr. Blvd / UNC Hospitals"
"6057" 22 "U" "U - Campus Shuttle"
"6154" 23 "F" "F - Colony Woods / Franklin St / McDougle School"
"6657" 24 "C" "C - UNC Campus / Smith Level"
stop_without_stop_time WARNING 10

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.
75 "8552226" "Mitchell Lane at Rosemary Street"
76 "8552227" "West Rosemary Street at Mini Mart Eastbound"
77 "8552228" "West Rosemary Street at Pritchard Avenue"
100 "8552251" "West Rosemary Street at Mini Mart"
101 "8552252" "Mitchell Lane at Rosemary Street"
102 "8552253" "Mitchell Lane at Lindsay Street"
155 "8552332" "Ephesus Church Road at Blue Hill Apartments"
344 "8555176" "Ephesus Church Road at Hamlin Park"
345 "8555177" "Ephesus Church Road at Legion Road Westbound"
531 "8581874" "West Rosemary Street at Pritchard Avenue Westbound"
trip_distance_exceeds_shape_distance_below_threshold WARNING 1294

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.

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

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.
"420_N_0645_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_0645_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_0715_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_0715_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_0745_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_0745_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1525_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1525_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1630_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1630_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1700_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1700_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1730_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1730_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1815_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1815_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1915_Mon - Fri" "27836" 26344.484364411484 26344.459408720595 0.0
"420_N_1915_Mon - Fri-7" "27836" 26344.484364411484 26344.459408720595 0.0
"CCX_A_0830_Mon - Fri" "21317" 9480.976786530146 9476.05806463378 0.0
"CCX_A_0830_Mon - Fri-7" "21317" 9480.976786530146 9476.05806463378 0.0
"CCX_A_0845_Mon - Fri" "21317" 9480.976786530146 9476.05806463378 0.0
"CCX_A_0845_Mon - Fri-7" "21317" 9480.976786530146 9476.05806463378 0.0
"CL_W_0654_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0654_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0714_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0714_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0734_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0734_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0754_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0754_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0814_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0814_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0834_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0834_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0854_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0854_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0914_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0914_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0944_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_0944_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1014_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1014_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1044_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1044_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1114_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1114_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1144_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1144_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1214_Mon - Fri" "21320" 10945.607374184507 10945.606773663309 0.0
"CL_W_1214_Mon - Fri-7" "21320" 10945.607374184507 10945.606773663309 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"