GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2025-12-13T06:45:43Z,
for the dataset file:///shared/horairesth-1bd0227c824c01.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
N/A
Publisher URL:
N/A
Feed Email:
N/A
Feed Language:
N/A

Files included


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

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 74
  • Shapes: 348
  • Stops: 1106
  • Trips: 806

Specification Compliance report

15244 notices reported (1106 errors, 14138 warnings, 0 infos)

Notice Code Severity Total
foreign_key_violation ERROR 1106

foreign_key_violation

Wrong foreign key.

A foreign key references the primary key of another file. A foreign key violation means that the foreign key referenced from a given row (the child file) cannot be found in the corresponding file (the parent file). The Foreign keys are defined in the specification under "Type" for each file.

You can see more about this notice here.

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

childFilename (?) The name of the file from which reference is made. childFieldName (?) The name of the field that makes reference. parentFilename (?) The name of the file that is referred to. parentFieldName (?) The name of the field that is referred to. fieldValue (?) The faulty record's value. csvRowNumber (?) The row of the faulty record.
"stops.txt" "parent_station" "stops.txt" "stop_id" "1858336" 2
"stops.txt" "parent_station" "stops.txt" "stop_id" "1858336" 3
"stops.txt" "parent_station" "stops.txt" "stop_id" "2558102" 4
"stops.txt" "parent_station" "stops.txt" "stop_id" "2558119" 5
"stops.txt" "parent_station" "stops.txt" "stop_id" "2558119" 6
"stops.txt" "parent_station" "stops.txt" "stop_id" "2597403" 7
"stops.txt" "parent_station" "stops.txt" "stop_id" "2597403" 8
"stops.txt" "parent_station" "stops.txt" "stop_id" "2601035" 9
"stops.txt" "parent_station" "stops.txt" "stop_id" "2601035" 10
"stops.txt" "parent_station" "stops.txt" "stop_id" "2639961" 11
"stops.txt" "parent_station" "stops.txt" "stop_id" "2639961" 12
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122798" 13
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122798" 14
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122813" 15
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122813" 16
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122814" 17
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122814" 18
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122822" 19
"stops.txt" "parent_station" "stops.txt" "stop_id" "3122822" 20
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123011" 21
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123011" 22
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123017" 23
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123017" 24
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123026" 25
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123026" 26
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123028" 27
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123028" 28
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123029" 29
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123029" 30
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123244" 31
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123244" 32
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123274" 33
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123274" 34
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123275" 35
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123275" 36
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123277" 37
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123277" 38
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123284" 39
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123284" 40
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123494" 41
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123494" 42
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123495" 43
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123495" 44
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123496" 45
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123496" 46
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123497" 47
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123497" 48
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123498" 49
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123498" 50
"stops.txt" "parent_station" "stops.txt" "stop_id" "3123499" 51
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 572

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 572 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.
"CALC_1890976" 161898 484.0 34 161897 484.0 33 0.3307036341574524
"CALC_1890976" 161939 1349.0 75 161938 1349.0 74 0.8383539240247692
"CALC_1890977" 163421 20607.0 798 163420 20607.0 797 0.3825777224653042
"CALC_1890978" 163910 3246.0 83 163909 3246.0 82 0.5889533304793328
"CALC_1890978" 164290 11384.0 463 164289 11384.0 462 0.4712727227546668
"CALC_1890979" 165352 16813.0 676 165351 16813.0 675 0.3307036341574524
"CALC_1890050" 36341 20794.0 875 36340 20794.0 874 0.8337623417188755
"CALC_1890050" 36364 21308.0 898 36363 21308.0 897 0.5613737746202898
"CALC_1890050" 36447 22474.0 981 36446 22474.0 980 0.6716769214344712
"CALC_1890052" 38114 15164.0 651 38113 15164.0 650 0.699996097020822
"CALC_1890053" 38497 5900.0 307 38496 5900.0 306 0.8462073338280325
"CALC_1890053" 38801 12828.0 611 38800 12828.0 610 0.7027607929270911
"CALC_1890054" 39323 5900.0 307 39322 5900.0 306 0.8462073338280325
"CALC_1890054" 39577 11532.0 561 39576 11532.0 560 0.7027607929270911
"CALC_1890055" 40099 5900.0 307 40098 5900.0 306 0.8462073338280325
"CALC_1890055" 40608 15936.0 816 40607 15936.0 815 0.5558763518921175
"CALC_1890055" 40628 16079.0 836 40627 16079.0 835 0.8701726125609903
"CALC_1890055" 40630 16086.0 838 40629 16086.0 837 0.7062072471060133
"CALC_1890056" 41501 5900.0 307 41500 5900.0 306 0.8462073338280325
"CALC_1890056" 42010 15936.0 816 42009 15936.0 815 0.5558763518921175
"CALC_1890057" 43171 5900.0 307 43170 5900.0 306 0.8462073338280325
"CALC_1890057" 43563 14176.0 699 43562 14176.0 698 0.5558763518921175
"CALC_1890970" 155372 19038.0 817 155371 19038.0 816 0.3307036341574524
"CALC_1890970" 155565 26415.0 1010 155564 26415.0 1009 0.3825777224653042
"CALC_1890970" 155951 35566.0 1396 155950 35566.0 1395 0.5911449235043812
"CALC_1890970" 156045 37704.0 1490 156044 37704.0 1489 0.8614571804087747
"CALC_1890058" 44724 5900.0 307 44723 5900.0 306 0.8462073338280325
"CALC_1890058" 45116 14176.0 699 45115 14176.0 698 0.5558763518921175
"CALC_1890058" 45136 14319.0 719 45135 14319.0 718 0.8701726125609903
"CALC_1890058" 45138 14326.0 721 45137 14326.0 720 0.7062072471060133
"CALC_1890059" 46009 5900.0 307 46008 5900.0 306 0.8462073338280325
"CALC_1890059" 46401 14176.0 699 46400 14176.0 698 0.5558763518921175
"CALC_1890059" 46421 14319.0 719 46420 14319.0 718 0.8701726125609903
"CALC_1890059" 46423 14326.0 721 46422 14326.0 720 0.7062072471060133
"CALC_1890972" 157740 3246.0 83 157739 3246.0 82 0.5889533304793328
"CALC_1890972" 158120 11384.0 463 158119 11384.0 462 0.4712727227546668
"CALC_1891941" 295476 13871.0 758 295475 13871.0 757 0.19090282998827102
"CALC_1890973" 159147 10219.0 434 159146 10219.0 433 0.3825777224653042
"CALC_1890973" 159537 22240.0 824 159536 22240.0 823 0.4712727227546668
"CALC_1891940" 293976 5192.0 265 293975 5192.0 264 0.19090282998827102
"CALC_1891940" 294369 12037.0 658 294368 12037.0 657 0.4469320561550761
"CALC_1891940" 294611 16723.0 900 294610 16723.0 899 0.5422164781117899
"CALC_1890974" 160630 20623.0 798 160629 20623.0 797 0.3825777224653042
"CALC_1890975" 161828 18721.0 778 161827 18721.0 777 0.3307036341574524
"CALC_1890602" 56370 3367.0 194 56369 3367.0 193 0.7030479036610254
"CALC_1890965" 151323 32245.0 1126 151322 32245.0 1125 0.19140601051479972
"CALC_1890603" 56593 2051.0 111 56592 2051.0 110 0.7030479036610254
"CALC_1890966" 151942 18119.0 608 151941 18119.0 607 0.1357848587708465
"CALC_1890966" 151958 18551.0 624 151957 18551.0 623 0.5177594101813555
"CALC_1890967" 152683 17094.0 617 152682 17094.0 616 0.77294240581569
missing_recommended_file WARNING 1

missing_recommended_file

A recommended file is missing.

You can see more about this notice here.

filename (?) The name of the faulty file.
"feed_info.txt"
missing_timepoint_value WARNING 11809

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 11809 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 "BJA0300|1" 1
3 "BJA0300|1" 2
4 "BJA0300|1" 3
5 "BJA0300|1" 4
6 "BJA0300|1" 5
7 "BJA0300|1" 6
8 "BJA0300|1" 7
9 "BJA0300|1" 8
10 "BJA0300|1" 9
11 "BJA0300|1" 10
12 "BJA0300|1" 11
13 "BJA0300|1" 12
14 "BJA0300|1" 13
15 "BJA0300|1" 14
16 "BJA0300|1" 15
17 "BJA0300|1" 16
18 "BJA0301|2" 1
19 "BJA0301|2" 2
20 "BJA0301|2" 3
21 "BJA0301|2" 4
22 "BJA0301|2" 5
23 "BJA0301|2" 6
24 "BJA0301|2" 7
25 "BJA0301|2" 8
26 "BJA0301|2" 9
27 "BJA0301|2" 10
28 "BJA0301|2" 11
29 "BJA0301|2" 12
30 "BJA0301|2" 13
31 "BJA0301|2" 14
32 "BJA0301|2" 15
33 "BJA0301|2" 16
34 "BJA0301|1" 1
35 "BJA0301|1" 2
36 "BJA0301|1" 3
37 "BJA0301|1" 4
38 "BJA0301|1" 5
39 "BJA0301|1" 6
40 "BJA0301|1" 7
41 "BJA0301|1" 8
42 "BJA0301|1" 9
43 "BJA0301|1" 10
44 "BJA0301|1" 11
45 "BJA0301|1" 12
46 "BJA0301|1" 13
47 "BJA0301|1" 14
48 "BJA0301|1" 15
49 "BJA0301|1" 16
50 "BJA0303|1" 1
51 "BJA0303|1" 2
mixed_case_recommended_field WARNING 1750

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 1750 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" "SATOLAS ET BONCE > BOURGOIN JALLIEU" 2
"trips.txt" "trip_headsign" "BOURGOIN JALLIEU > SATOLAS ET BONCE" 3
"trips.txt" "trip_headsign" "BOURGOIN JALLIEU > SATOLAS ET BONCE" 4
"trips.txt" "trip_headsign" "BOURGOIN JALLIEU > SATOLAS ET BONCE" 5
"trips.txt" "trip_headsign" "JANNEYRIAS > BOURGOIN JALLIEU" 6
"trips.txt" "trip_headsign" "BOURGOIN JALLIEU > JANNEYRIAS" 7
"trips.txt" "trip_headsign" "BOURGOIN JALLIEU > JANNEYRIAS" 8
"trips.txt" "trip_headsign" "SATOLAS ET BONCE > CREMIEU" 9
"trips.txt" "trip_headsign" "CREMIEU > SATOLAS ET BONCE" 10
"trips.txt" "trip_headsign" "CREMIEU > SATOLAS ET BONCE" 11
"trips.txt" "trip_headsign" "CHARVIEU CHAVAGNEUX > DAGNEUX" 12
"trips.txt" "trip_headsign" "DAGNEUX > CHARVIEU CHAVAGNEUX" 13
"trips.txt" "trip_headsign" "DAGNEUX > CHARVIEU CHAVAGNEUX" 14
"trips.txt" "trip_headsign" "ANTHON > DAGNEUX" 15
"trips.txt" "trip_headsign" "DAGNEUX > ANTHON" 16
"trips.txt" "trip_headsign" "DAGNEUX > ANTHON" 17
"trips.txt" "trip_headsign" "TIGNIEU JAMEYZIEU > DAGNEUX" 18
"trips.txt" "trip_headsign" "DAGNEUX > TIGNIEU JAMEYZIEU" 19
"trips.txt" "trip_headsign" "DAGNEUX > TIGNIEU JAMEYZIEU" 20
"trips.txt" "trip_headsign" "VILLETTE D'ANTHON > DAGNEUX" 21
"trips.txt" "trip_headsign" "DAGNEUX > JANNEYRIAS" 22
"trips.txt" "trip_headsign" "DAGNEUX > JANNEYRIAS" 23
"trips.txt" "trip_headsign" "TIGNIEU JAMEYZIEU > DAGNEUX" 24
"trips.txt" "trip_headsign" "DAGNEUX > TIGNIEU JAMEYZIEU" 25
"trips.txt" "trip_headsign" "DAGNEUX > TIGNIEU JAMEYZIEU" 26
"trips.txt" "trip_headsign" "SAINT ROMAIN DE JALIONAS > DAGNEUX" 27
"trips.txt" "trip_headsign" "DAGNEUX > SAINT ROMAIN DE JALIONAS" 28
"trips.txt" "trip_headsign" "DAGNEUX > SAINT ROMAIN DE JALIONAS" 29
"trips.txt" "trip_headsign" "ANTHON > GENAS" 30
"trips.txt" "trip_headsign" "GENAS > ANTHON" 31
"trips.txt" "trip_headsign" "GENAS > ANTHON" 32
"trips.txt" "trip_headsign" "SAINT ROMAIN DE JALIONAS > GENAS" 33
"trips.txt" "trip_headsign" "GENAS > SAINT ROMAIN DE JALIONAS" 34
"trips.txt" "trip_headsign" "GENAS > SAINT ROMAIN DE JALIONAS" 35
"trips.txt" "trip_headsign" "VALENCIN > HEYRIEUX" 36
"trips.txt" "trip_headsign" "HEYRIEUX > SAINT JUST CHALEYSSIN" 37
"trips.txt" "trip_headsign" "HEYRIEUX > SAINT JUST CHALEYSSIN" 38
"trips.txt" "trip_headsign" "HEYRIEUX > SAINT JUST CHALEYSSIN" 39
"trips.txt" "trip_headsign" "HEYRIEUX > SAINT JUST CHALEYSSIN" 40
"trips.txt" "trip_headsign" "VALENCIN > HEYRIEUX" 41
"trips.txt" "trip_headsign" "HEYRIEUX > VALENCIN" 42
"trips.txt" "trip_headsign" "HEYRIEUX > VALENCIN" 43
"trips.txt" "trip_headsign" "VALENCIN > HEYRIEUX" 44
"trips.txt" "trip_headsign" "HEYRIEUX > VALENCIN" 45
"trips.txt" "trip_headsign" "HEYRIEUX > VALENCIN" 46
"trips.txt" "trip_headsign" "SAINT JUST CHALEYSSIN > HEYRIEUX" 47
"trips.txt" "trip_headsign" "ROCHE > L ISLE D ABEAU" 48
"trips.txt" "trip_headsign" "L ISLE D ABEAU > ROCHE" 49
"trips.txt" "trip_headsign" "L ISLE D ABEAU > ROCHE" 50
"trips.txt" "trip_headsign" "L ISLE D ABEAU > ROCHE" 51
stop_too_far_from_shape WARNING 3

stop_too_far_from_shape

Stop too far from trip shape.

Per GTFS Best Practices, route alignments (in shapes.txt) should be within 100 meters of stop locations which a trip serves. This potentially indicates a problem with the location of the stop or the path of the shape.

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.
53 "CALC_1890050" "IDB0305|2" 513 "18616" "CAFE GIROUD" [45.653428,5.20176] 118.15520017347217
52 "CALC_1890051" "IDB0302|1" 502 "18617" "CAFE GIROUD" [45.653428,5.20176] 134.29038614498526
55 "CALC_1890049" "IDB0307|1" 550 "18616" "CAFE GIROUD" [45.653428,5.20176] 118.15520017347217
stops_match_shape_out_of_order WARNING 3

stops_match_shape_out_of_order

Two stop entries are different than their arrival-departure order defined by shapes.txt.

This could indicate a problem with the location of the stops, the path of the shape, or the sequence of the stops for their trip.

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. stopTimeCsvRowNumber1 (?) The row number of the first faulty record from `stop_times.txt`. stopId1 (?) The id of the first stop that is referred to. stopName1 (?) The name of the first stop that is referred to. match1 (?) Latitude and longitude pair of the first matching location. stopTimeCsvRowNumber2 (?) The row number of the second faulty record from `stop_times.txt`. stopId2 (?) The id of the second stop that is referred to. stopName2 (?) The name of the second stop that is referred to. match2 (?) Latitude and longitude pair of the second matching location.
769 "CALC_1892272" "VIE1204|1" 11369 "20606" "PLACE DE LA ST VINCENT" [45.49254263404469,4.945551907607742] 11368 "21158" "PLACE DE LA ST VINCENT" [45.49257075825957,4.94539031317839]
767 "CALC_1892267" "VIE1202|1" 11341 "20606" "PLACE DE LA ST VINCENT" [45.49254263404469,4.945551907607742] 11340 "21158" "PLACE DE LA ST VINCENT" [45.49257075825957,4.94539031317839]
765 "CALC_1892266" "VIE1200|1" 11323 "20606" "PLACE DE LA ST VINCENT" [45.49254263404469,4.945551907607742] 11322 "21158" "PLACE DE LA ST VINCENT" [45.49257075825957,4.94539031317839]