astuces — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-19T21:16:27Z,
for the dataset file:///shared/astuces_e890d503.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
CITYWAY
Publisher URL:
http://cityway.fr
Feed Email:
N/A
Feed Language:
French
Feed Start Date:
2026-04-28
Feed End Date:
2026-11-01

Files included


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

Counts


  • Agencies: 4
  • Blocks: 96
  • Routes: 112
  • Shapes: 600
  • Stops: 3793
  • Trips: 23443

Specification Compliance report

108519 notices reported (16 errors, 101235 warnings, 7268 infos)

Notice Code Severity Total
equal_shape_distance_diff_coordinates ERROR 16

equal_shape_distance_diff_coordinates

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 the 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 different coordinates indicate an error.

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.
"TAE:3883$104R$31" 16560 12101.0 400 16559 12101.0 399 955.9937356140275
"TAE:3883$104R$31" 16632 14646.0 472 16631 14646.0 471 956.1983278801451
"TAE:3883$ARF$34" 1471 5618.0 277 1470 5618.0 276 19.341073704365506
"TAE:3883$104A$5" 17250 9384.0 339 17249 9384.0 338 1487.167956775046
"TAE:3883$D1R$46" 24927 1105.0 52 24926 1105.0 51 435.1334844709307
"TAE:3883$D1R$46" 24944 1543.0 69 24943 1543.0 68 395.5647052521437
"TAE:3883$AAD$10" 895 1524.0 68 894 1524.0 67 19.341073704365506
"TAE:3883$106R$32" 30587 831.0 57 30586 831.0 56 332.85704395634724
"TAE:3883$D1A$19" 24807 6692.0 351 24806 6692.0 350 19.341073704365506
"TAE:3883$100R$27" 29552 6071.0 257 29551 6071.0 256 576.8847654408235
"TAE:3883$100A$1" 28763 2832.0 126 28762 2832.0 125 28.303692307279864
"TAE:3883$100A$1" 29092 15703.0 455 29091 15703.0 454 1578.4446327490487
"TAE:3883$AA$8" 69 1524.0 68 68 1524.0 67 19.341073704365506
"TAE:3883$311A$7" 31275 2832.0 126 31274 2832.0 125 28.303692307279864
"TAE:3883$102A$3" 14314 2832.0 126 14313 2832.0 125 28.303692307279864
"TAE:3883$AR$35" 2027 9615.0 487 2026 9615.0 486 19.341073704365506
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 581

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.

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

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.
"TAE:3883$IA$26" 20812 2532.0 62 20811 2532.0 61 0.47188615629833264
"TAE:3883$IA$26" 20828 2640.0 78 20827 2640.0 77 0.651983701702392
"TAE:3883$IA$26" 20995 5472.0 245 20994 5472.0 244 0.14490246408534035
"TAE:3883$IA$26" 20997 5509.0 247 20996 5509.0 246 0.0724512433714914
"TAE:3883$IA$26" 21024 5709.0 274 21023 5709.0 273 0.14490524978281888
"TAE:3883$IA$26" 21078 6579.0 328 21077 6579.0 327 0.776987914767132
"TAE:3883$IA$26" 21083 6592.0 333 21082 6592.0 332 0.49990493769309235
"TAE:3883$IA$26" 21086 6599.0 336 21085 6599.0 335 0.3622498142581938
"TAE:3883$IA$26" 21183 8142.0 433 21182 8142.0 432 0.45723651660398607
"TAE:3883$IA$26" 21191 8195.0 441 21190 8195.0 440 0.06521652038082988
"TAE:3883$IA$26" 21213 8482.0 463 21212 8482.0 462 0.2246259251579787
"TAE:3883$IA$26" 21261 9630.0 511 21260 9630.0 510 0.07245875168178807
"TAE:3883$IA$26" 21427 11475.0 677 21426 11475.0 676 0.28263063168379005
"TAE:3883$IA$26" 21439 11552.0 689 21438 11552.0 688 0.28262885784662767
"TAE:3883$BAF$14" 7071 3030.0 140 7070 3030.0 139 0.07254530610042184
"TAE:3883$103A$4" 15926 2333.0 121 15925 2333.0 120 0.42872188769224906
"TAE:3883$GR$52" 19765 5060.0 174 19764 5060.0 173 0.07243920173165593
"TAE:3883$GR$52" 19778 5238.0 187 19777 5238.0 186 0.28975114526198964
"TAE:3883$GR$52" 19899 7487.0 308 19898 7487.0 307 0.21724787098450343
"TAE:3883$GR$52" 19907 7522.0 316 19906 7522.0 315 0.07241563122434784
"TAE:3883$GR$52" 19964 8329.0 373 19963 8329.0 372 0.48504508131628243
"TAE:3883$GR$52" 19969 8339.0 378 19968 8339.0 377 0.48504523983599857
"TAE:3883$GR$52" 20102 11396.0 511 20101 11396.0 510 0.5795803386216818
"TAE:3883$GR$52" 20189 13513.0 598 20188 13513.0 597 0.21737185813571336
"TAE:3883$GR$52" 20227 13930.0 636 20226 13930.0 635 0.4466973694469598
"TAE:3883$GR$52" 20258 14049.0 667 20257 14049.0 666 0.4595771187495129
"TAE:3883$GR$52" 20326 15017.0 735 20325 15017.0 734 0.137681294593362
"TAE:3883$GR$52" 20437 16977.0 846 20436 16977.0 845 0.1449647249297388
"TAE:3883$GR$52" 20451 17032.0 860 20450 17032.0 859 0.606363914863486
"TAE:3883$GR$52" 20493 17749.0 902 20492 17749.0 901 0.856202279764221
"TAE:3883$GR$52" 20526 18044.0 935 20525 18044.0 934 0.07249565052216397
"TAE:3883$GR$52" 20536 18063.0 945 20535 18063.0 944 0.512476019934752
"TAE:3883$GR$52" 20566 18911.0 975 20565 18911.0 974 0.42254138388173157
"TAE:3883$GR$52" 20596 19558.0 1005 20595 19558.0 1004 0.07251466163729846
"TAE:3883$GR$52" 20714 21662.0 1123 20713 21662.0 1122 0.8450827684707873
"TAE:3883$GR$52" 20738 21859.0 1147 20737 21859.0 1146 0.07252151408157828
"TAE:3883$104R$31" 16166 80.0 6 16165 80.0 5 0.07249568981239547
"TAE:3883$104R$31" 16190 652.0 30 16189 652.0 29 0.0724988950914636
"TAE:3883$104R$31" 16196 908.0 36 16195 908.0 35 0.47523273305657965
"TAE:3883$104R$31" 16203 974.0 43 16202 974.0 42 0.07249823275453149
"TAE:3883$104R$31" 16206 981.0 46 16205 981.0 45 0.14499628570538414
"TAE:3883$104R$31" 16223 1016.0 63 16222 1016.0 62 0.5124813053766888
"TAE:3883$104R$31" 16227 1056.0 67 16226 1056.0 66 0.07249853589866787
"TAE:3883$104R$31" 16332 3498.0 172 16331 3498.0 171 0.14502861615732912
"TAE:3883$104R$31" 16335 3502.0 175 16334 3502.0 174 0.0725143192458593
"TAE:3883$104R$31" 16631 14646.0 471 16630 14646.0 470 0.28993504182904345
"TAE:3883$104R$31" 16708 16207.0 548 16707 16207.0 547 0.7173896038337824
"TAE:3883$104R$31" 16755 16559.0 595 16754 16559.0 594 0.4287108997654025
"TAE:3883$104R$31" 16782 16915.0 622 16781 16915.0 621 0.44092749929546515
"TAE:3883$D2A$20" 27841 235.0 16 27840 235.0 15 0.5568832115695661
fast_travel_between_consecutive_stops WARNING 1

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.
17636 "TCAR:27601" "TCAR:530" 395.71644485314704 6.595274080885784 443262 20 "TCAR:MJPLA2" "Place Joseph Lefèbvre" "16:13:00" 443263 21 "TCAR:DUROU1" "Route du Halage" "16:13:00"
missing_bike_allowance WARNING 92

missing_bike_allowance

Ferry trips should include bike allowance information.

All ferry trips should have a valid value in the bikes_allowed field in trips.txt.

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record. routeId (?) The faulty record's route id. tripId (?) The faulty record's trip id.
4330 "TCAR:99" "TCAR:12002"
4331 "TCAR:99" "TCAR:12003"
4332 "TCAR:99" "TCAR:12004"
4333 "TCAR:99" "TCAR:12005"
4334 "TCAR:99" "TCAR:12006"
4335 "TCAR:99" "TCAR:12007"
4336 "TCAR:99" "TCAR:12008"
4337 "TCAR:99" "TCAR:12009"
4339 "TCAR:99" "TCAR:12010"
4340 "TCAR:99" "TCAR:12011"
4341 "TCAR:99" "TCAR:12012"
4342 "TCAR:99" "TCAR:12013"
4343 "TCAR:99" "TCAR:12014"
4344 "TCAR:99" "TCAR:12015"
4345 "TCAR:99" "TCAR:12016"
4346 "TCAR:99" "TCAR:12017"
4347 "TCAR:99" "TCAR:12018"
4348 "TCAR:99" "TCAR:12019"
4350 "TCAR:99" "TCAR:12020"
4351 "TCAR:99" "TCAR:12021"
4352 "TCAR:99" "TCAR:12022"
4353 "TCAR:99" "TCAR:12023"
4354 "TCAR:99" "TCAR:12024"
4355 "TCAR:99" "TCAR:12025"
4356 "TCAR:99" "TCAR:12026"
4357 "TCAR:99" "TCAR:12027"
4358 "TCAR:99" "TCAR:12028"
4359 "TCAR:99" "TCAR:12029"
4361 "TCAR:99" "TCAR:12030"
4362 "TCAR:99" "TCAR:12031"
4363 "TCAR:99" "TCAR:12032"
4364 "TCAR:99" "TCAR:12033"
4365 "TCAR:99" "TCAR:12034"
4366 "TCAR:99" "TCAR:12035"
4367 "TCAR:99" "TCAR:12036"
4368 "TCAR:99" "TCAR:12037"
4369 "TCAR:99" "TCAR:12038"
4370 "TCAR:99" "TCAR:12039"
4372 "TCAR:99" "TCAR:12040"
4373 "TCAR:99" "TCAR:12041"
4374 "TCAR:99" "TCAR:12042"
4375 "TCAR:99" "TCAR:12043"
4376 "TCAR:99" "TCAR:12044"
4377 "TCAR:99" "TCAR:12045"
4378 "TCAR:99" "TCAR:12046"
4379 "TCAR:99" "TCAR:12047"
4382 "TCAR:99" "TCAR:12063"
4383 "TCAR:99" "TCAR:12064"
4384 "TCAR:99" "TCAR:12065"
4385 "TCAR:99" "TCAR:12066"
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_timepoint_value WARNING 100000

missing_timepoint_value

stop_times.timepoint value is missing for a record.

When at least one of stop_times.arrival_time or stop_times.departure_time are provided, stop_times.timepoint should be defined

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record. tripId (?) The faulty record's `stop_times.trip_id`. stopSequence (?) The faulty record's `stop_times.stop_sequence`.
2 "TAE:BLMM2BHI" 1
3 "TAE:BLMM2BHI" 2
4 "TAE:BLMM2BHI" 3
5 "TAE:BLMM2BHI" 4
6 "TAE:BLMM2BHI" 5
7 "TAE:BLMM2BHI" 6
8 "TAE:BLMM2BHI" 7
9 "TAE:BLMM2BHI" 8
10 "TAE:BLMM2BHI" 9
11 "TAE:BLMM2BHI" 10
12 "TAE:BLMM2BHI" 11
13 "TAE:BLMM2BHI" 12
14 "TAE:BLMM2BHI" 13
15 "TAE:BLMM2BHI" 14
16 "TAE:BLMM2BHI" 15
17 "TAE:BLMM2BHI" 16
18 "TAE:BLMM2BHI" 17
19 "TAE:BLMM2BHI" 18
20 "TAE:BLMM2BHI" 19
21 "TAE:BLMM2BHI" 20
22 "TAE:BLMM2BHI" 21
23 "TAE:BLMM2BHI" 22
24 "TAE:BLMM2BHI" 23
25 "TAE:BLMM2BHI" 24
26 "TAE:BLMM2BHI" 25
27 "TAE:BLMM2BHI" 26
28 "TAE:BLMM2BHI" 27
29 "TAE:BLMM2BHI" 28
30 "TAE:BLMM2BHI" 29
31 "TAE:BLMM2BHI" 30
32 "TAE:BLMM2BHI" 31
33 "TAE:BLMM2BHY" 1
34 "TAE:BLMM2BHY" 2
35 "TAE:BLMM2BHY" 3
36 "TAE:BLMM2BHY" 4
37 "TAE:BLMM2BHY" 5
38 "TAE:BLMM2BHY" 6
39 "TAE:BLMM2BHY" 7
40 "TAE:BLMM2BHY" 8
41 "TAE:BLMM2BHY" 9
42 "TAE:BLMM2BHY" 10
43 "TAE:BLMM2BHY" 11
44 "TAE:BLMM2BHY" 12
45 "TAE:BLMM2BHY" 13
46 "TAE:BLMM2BHY" 14
47 "TAE:BLMM2BHY" 15
48 "TAE:BLMM2BHY" 16
49 "TAE:BLMM2BHY" 17
50 "TAE:BLMM2BHY" 18
51 "TAE:BLMM2BHY" 19
mixed_case_recommended_field WARNING 540

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 540 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.
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2955
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2956
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2957
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2958
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2959
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2961
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2962
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2963
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2964
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2965
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2966
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2967
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2968
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2969
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2970
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2972
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2973
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2974
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2975
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2976
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2977
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2978
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2979
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2980
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2981
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2983
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2984
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2985
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2986
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2987
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2988
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2989
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2990
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2991
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2992
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2994
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2995
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2996
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2997
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2998
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 2999
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3000
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3001
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3002
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3003
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3005
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3006
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3007
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3008
"trips.txt" "trip_headsign" "ESIGELEC SAINT-ÉTIENNE-DU-ROUVRAY" 3009
route_color_contrast WARNING 2

route_color_contrast

Insufficient route color contrast.

A route's color and route_text_color should be contrasting.

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeColor (?) The faulty record's HTML route color. routeTextColor (?) The faulty record's HTML route text color.
"TCAR:26" 54 "#0069B4" "#1D1D1B"
"TCAR:530" 101 "#D20A11" "#1D1D1B"
route_long_name_contains_short_name WARNING 17

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`.
"TAE:100" 2 "100" "100"
"TAE:101" 3 "101" "101"
"TAE:102" 4 "102" "102"
"TAE:103" 5 "103" "103"
"TAE:104" 6 "104" "104"
"TAE:106" 7 "106" "106"
"TAE:311" 8 "311" "311"
"TAE:A" 9 "A" "A"
"TAE:B" 10 "B" "B"
"TAE:C" 11 "C" "C"
"TAE:D1" 12 "D1" "D1"
"TAE:D2" 13 "D2" "D2"
"TAE:F" 14 "F" "F"
"TAE:F9" 15 "F9" "F9"
"TAE:G" 16 "G" "G"
"TAE:I" 17 "I" "I"
"TCAR:60" 102 "Astuce Pro" "Astuce Pro"
stop_without_stop_time WARNING 1

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.
3108 "TCAR:PCORN4" "Pont Corneille"
feed_valid_beyond_total_service_window INFO 1

feed_valid_beyond_total_service_window

The feed is valid 14 days beyond its total service window.

You can see more about this notice here.

feedStartDate (?) The feed start date from feed_info.txt. feedEndDate (?) The feed end date from feed_info.txt. serviceWindowStartDate (?) The earliest active service date across all services. serviceWindowEndDate (?) The latest active service date across all services.
"2026-04-28" "2026-11-01" "2026-06-18" "2026-11-01"
unsorted_stop_times INFO 7267

unsorted_stop_times

Stop times are not sorted by trip_id and stop_sequence.

'stop_times.txt' entries for a given trip are not sorted by stop_sequence, or are not contiguous in the file.

You can see more about this notice here.

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

tripId (?) The faulty record's trip_id. startCsvRowNumber (?) CSV row number of the first stop_times entry for this trip. endCsvRowNumber (?) CSV row number of the last stop_times entry for this trip.
"TCAR:12706" 138765 194386
"TCAR:12707" 131086 150442
"TCAR:12709" 128600 151579
"TCAR:12701" 134311 148666
"TCAR:12703" 130696 150536
"TCAR:24713" 436046 436632
"TCAR:24712" 438380 449115
"TCAR:24710" 434609 435440
"TCAR:12732" 149633 201220
"TCAR:12733" 149777 196382
"TCAR:6900" 509242 571233
"TCAR:11404" 19102 35410
"TCAR:12735" 151640 201140
"TCAR:6901" 510700 522867
"TCAR:11405" 10159 35169
"TCAR:12727" 148901 152069
"TCAR:24708" 436846 437844
"TCAR:24705" 434045 434311
"TCAR:12721" 143429 194144
"TCAR:12722" 168259 192186
"TCAR:12723" 148800 197985
"TCAR:12724" 148727 240673
"TCAR:6913" 522348 571492
"TCAR:6904" 548069 561653
"TCAR:12718" 147770 200093
"TCAR:12719" 138189 195022
"TCAR:6907" 524357 569804
"TCAR:6922" 524025 558197
"TCAR:6923" 522928 559187
"TCAR:6924" 523097 560934
"TCAR:6915" 522523 570266
"TCAR:6916" 522608 559637
"TCAR:6919" 559638 562477
"TCAR:6932" 570805 575104
"TCAR:6935" 558218 562307
"TCAR:6929" 561714 601333
"TCAR:6943" 571213 571806
"TCAR:6945" 558570 571746
"TCAR:6938" 557809 562898
"TCAR:6950" 560975 561989
"TCAR:6951" 562518 569942
"TCAR:6952" 561037 570622
"TCAR:5619" 478744 478839
"TCAR:6947" 569825 570505
"TCAR:6948" 559228 561819
"TCAR:6960" 559723 571119
"TCAR:6962" 561840 570943
"TCAR:6964" 570066 571652
"TCAR:6965" 601487 602344
"TCAR:6967" 570307 570658