GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-19T23:50:35Z,
for the dataset file:///shared/tpv_aacb97f2.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Mobilités M - Pays Voironnais
Feed Email:
N/A
Feed Language:
French

Files included


  1. agency.txt
  2. booking_rules.txt
  3. calendar.txt
  4. calendar_dates.txt
  5. fare_attributes.txt
  6. fare_rules.txt
  7. feed_info.txt
  8. frequencies.txt
  9. routes.txt
  10. shapes.txt
  11. stop_times.txt
  12. stops.txt
  13. transfers.txt
  14. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 87
  • Shapes: 193
  • Stops: 1193
  • Trips: 821

Specification Compliance report

344 notices reported (0 errors, 304 warnings, 40 infos)

Notice Code Severity Total
equal_shape_distance_same_coordinates WARNING 196

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 196 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`.
"TPV_39_4" 22625 8230.55 80 22624 8230.55 79
"TPV_39_4" 22646 9917.29 101 22645 9917.29 100
"TPV_39_4" 22653 11250.56 108 22652 11250.56 107
"TPV_39_4" 22668 13268.2 123 22667 13268.2 122
"TPV_39_4" 22670 13290.06 125 22669 13290.06 124
"TPV_39_2" 48091 2.92 3 48090 2.92 2
"TPV_39_2" 48095 36.62 7 48094 36.62 6
"TPV_39_2" 48098 128.39 10 48097 128.39 9
"TPV_39_2" 48100 154.94 12 48099 154.94 11
"TPV_39_2" 48103 192.71 15 48102 192.71 14
"TPV_39_2" 48107 324.53 19 48106 324.53 18
"TPV_39_2" 48113 497.19 25 48112 497.19 24
"TPV_39_2" 48116 516.21 28 48115 516.21 27
"TPV_39_2" 48118 531.64 30 48117 531.64 29
"TPV_39_2" 48122 549.92 34 48121 549.92 33
"TPV_39_2" 48127 644.12 39 48126 644.12 38
"TPV_39_2" 48133 729.55 45 48132 729.55 44
"TPV_39_2" 48139 802.8 51 48138 802.8 50
"TPV_39_2" 48144 873.98 56 48143 873.98 55
"TPV_39_2" 48146 935.75 58 48145 935.75 57
"TPV_39_2" 48148 958.65 60 48147 958.65 59
"TPV_39_2" 48153 1053.09 65 48152 1053.09 64
"TPV_39_2" 48156 1178.7 68 48155 1178.7 67
"TPV_39_2" 48162 1346.0 74 48161 1346.0 73
"TPV_39_2" 48165 1373.47 77 48164 1373.47 76
"TPV_39_2" 48170 1423.61 82 48169 1423.61 81
"TPV_39_2" 48182 1787.95 94 48181 1787.95 93
"TPV_39_2" 48190 1966.08 102 48189 1966.08 101
"TPV_39_2" 48247 4450.34 159 48246 4450.34 158
"TPV_39_2" 48250 4541.06 162 48249 4541.06 161
"TPV_39_2" 48252 4614.93 164 48251 4614.93 163
"TPV_39_2" 48255 4740.71 167 48254 4740.71 166
"TPV_39_2" 48259 4814.71 171 48258 4814.71 170
"TPV_39_2" 48261 4844.45 173 48260 4844.45 172
"TPV_39_2" 48268 4981.5 180 48267 4981.5 179
"TPV_39_2" 48278 5137.75 190 48277 5137.75 189
"TPV_39_2" 48281 5153.77 193 48280 5153.77 192
"TPV_39_2" 48285 5171.81 197 48284 5171.81 196
"TPV_39_2" 48288 5219.73 200 48287 5219.73 199
"TPV_39_2" 48292 5370.58 204 48291 5370.58 203
"TPV_39_2" 48295 5457.7 207 48294 5457.7 206
"TPV_39_2" 48298 5589.74 210 48297 5589.74 209
"TPV_39_2" 48302 5740.62 214 48301 5740.62 213
"TPV_39_2" 48304 5775.64 216 48303 5775.64 215
"TPV_39_2" 48307 5813.73 219 48306 5813.73 218
"TPV_39_2" 48329 6868.31 241 48328 6868.31 240
"TPV_39_2" 48344 7282.05 256 48343 7282.05 255
"TPV_39_2" 48347 7555.08 259 48346 7555.08 258
"TPV_39_2" 48353 7796.09 265 48352 7796.09 264
"TPV_39_2" 48359 7960.8 271 48358 7960.8 270
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 4

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_start_date"
"feed_info.txt" 2 "feed_end_date"
"feed_info.txt" 2 "feed_version"
"fare_attributes.txt" 2 "agency_id"
mixed_case_recommended_field WARNING 87

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 87 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.
"routes.txt" "route_long_name" "TULLINS - VOUREY - MOIRANS - VOIRON" 2
"routes.txt" "route_long_name" "REAUMONT LE GUICHARD - MOIRANS BEGHIN" 3
"routes.txt" "route_long_name" "APPRIEU LE RIVIER - MOIRANS BEGHIN" 4
"routes.txt" "route_long_name" "RIVES LES ABATTOIRS - MOIRANS BEGHIN" 5
"routes.txt" "route_long_name" "TULLINS CONDORCET - MOIRANS P. BEGHIN" 6
"routes.txt" "route_long_name" "TULLINS GARE SNCF - MOIRANS P. BEGHIN" 7
"routes.txt" "route_long_name" "VOREPPE L'ARCADE - MOIRANS P. BEGHIN" 8
"routes.txt" "route_long_name" "VOREPPE VOLOUISE - MOIRANS P. BEGHIN" 9
"routes.txt" "route_long_name" "FONTANIL CROIX ROCHETTE - MOIRANS BEGHIN" 10
"routes.txt" "route_long_name" "MOIRANS ESPACE JAIL - ST JEAN - BEGHIN" 11
"routes.txt" "route_long_name" "MERLAS PICOUDIERE - CHIRENS COLLEGE" 12
"routes.txt" "route_long_name" "ST SULPICE RIVOIRES - CHIRENS COLLEGE" 13
"routes.txt" "route_long_name" "LE PIN LES ALLEX - CHIRENS COLLEGE" 14
"routes.txt" "route_long_name" "PALADRU TROIS CHENES - CHIRENS COLLEGE" 15
"routes.txt" "route_long_name" "MONTFERRAT LE VERNEY - CHIRENS COLLEGE" 16
"routes.txt" "route_long_name" "CHARAVINES MONTFOLLET - CHIRENS COLLEGE" 17
"routes.txt" "route_long_name" "CHARAVINES PLACE MARCHE CHIRENS COLLEGE" 18
"routes.txt" "route_long_name" "BILIEU PETIT BILIEU - CHIRENS COLLEGE" 19
"routes.txt" "route_long_name" "LE PIN ST CHRISTOPHE - CHIRENS COLLEGE" 20
"routes.txt" "route_long_name" "TULLINS GOUY - CAMILLE DESMOULINS" 21
"routes.txt" "route_long_name" "TULLINS ST J. CHEPY - COLLEGE CONDORCET" 22
"routes.txt" "route_long_name" "MIRIBEL EGLISE - VOIRON GARE SUD" 23
"routes.txt" "route_long_name" "ST BLAISE RAVIGNHOUSE - RIVES DESNOS" 24
"routes.txt" "route_long_name" "REAUMONT H. FERROVIAIRE - RIVES DESNOS" 25
"routes.txt" "route_long_name" "REAUMONT LE BESSEY - RIVES DESNOS" 26
"routes.txt" "route_long_name" "ST GEOIRE COTAGON - VOIRON GARE NORD" 27
"routes.txt" "route_long_name" "CHARANCIEU - VOIRON GARE NORD" 28
"routes.txt" "route_long_name" "LA MURETTE VILLAGE - VOIRON LA GARENNE" 29
"routes.txt" "route_long_name" "ST CASSIEN MALOZA - VOIRON LA GARENNE" 30
"routes.txt" "route_long_name" "MOIRANS PETIT CRIEL - LA GARENNE" 31
"routes.txt" "route_long_name" "VOIRON LAVOIR CRIEL - LA GARENNE" 32
"routes.txt" "route_long_name" "LA MURETTE COURATIERE - VOIRON GARENNE" 33
"routes.txt" "route_long_name" "VOIRON LES TUILIERES - VOIRON LA GARENNE" 34
"routes.txt" "route_long_name" "RIVES - VOIRON GARE SUD" 35
"routes.txt" "route_long_name" "VOIRON GARE SUD - VOIRON LA MARTELIERE" 36
"routes.txt" "route_long_name" "POMMIERS RD 520 VILLAGE - VOREPPE MAIRIE" 37
"routes.txt" "route_long_name" "LA BUISSE GIRATOIRE - MOIRANS VIA CENTRALP" 38
"routes.txt" "route_long_name" "LA BUISSE ECOLE - COUBLEVIE PLAN MENU" 39
"routes.txt" "route_long_name" "LA BUISSE AFIPH - COUBLEVIE PLAN MENU" 40
"routes.txt" "route_long_name" "POMMIERS BARNIERS - COUBLEVIE PLAN MENU" 41
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - COUBLEVIE PLAN MENU" 42
"routes.txt" "route_long_name" "MIRIBEL LE VERNEY - COUBLEVIE PLAN MENU" 43
"routes.txt" "route_long_name" "CROSSEY GATELIERE - COUBLEVIE PLAN MENU" 44
"routes.txt" "route_long_name" "CROSSEY POMPIERS - COUBLEVIE PLAN MENU" 45
"routes.txt" "route_long_name" "CROSSEY TOLVON - COUBLEVIE PLAN MENU" 46
"routes.txt" "route_long_name" "VOIRON GARE NORD - COUBLEVIE PLAN MENU" 47
"routes.txt" "route_long_name" "REAUMONT BOURG -ST BLAISE MAIRIE" 48
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - ST AUPRE VILLAGE" 49
"routes.txt" "route_long_name" "MERLAS PICOUDIERE - ST GEOIRE PLAMPALAIS" 50
"routes.txt" "route_long_name" "ST GEOIRE CONSUOZ ABRIS - LAMBERTIERE" 51
stop_too_far_from_shape WARNING 7

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.
806 "TPV_516_2" "1000412-1001850" 13359 "1000718" "Tullins, GARE SNCF" [45.30116000000001,5.49037] 118.11341628774245
298 "TPV_575_2" "1000147-1000554" 10783 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
367 "TPV_537_2" "1000098-1000425" 10749 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
493 "TPV_511_2" "1000403-1001827" 12893 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
5 "TPV_511_3" "1000403-1001828" 12905 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
144 "TPV_512_2" "1000161-1000582" 13536 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
55 "TPV_593_1" "1000228-1001204" 6886 "1000544" "Saint-Geoire-en-Valdaine, VILLAGE" [45.45513,5.636250000000001] 173.96760906918294
stops_match_shape_out_of_order WARNING 9

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.
615 "TPV_503_1" "1000156-1000572" 13749 "1001020" "La Sure en Chartreuse, TENNIS" [45.318689944336406,5.664379054333386] 13748 "1001412" "La Sure en Chartreuse, COL DE LA PLACETTE" [45.33030517219248,5.658188146498817]
315 "TPV_585_4" "1000337-1001698" 286 "1001672" "Tullins, COLLEGE CONDORCET" [45.29804,5.486649999999999] 285 "1001694" "Tullins, ECOLE DESMOULINS" [45.29870620289897,5.485218417850237]
325 "TPV_593_2" "1000727-1003355" 10686 "1000950" "Saint-Geoire-en-Valdaine, LA COMBE" [45.45513059754709,5.636255975445429] 10685 "1000590" "Saint-Geoire-en-Valdaine, LAMBERTIERE" [45.451297779865804,5.632716264303727]
744 "TPV_593_2" "1000770-1003453" 10402 "1000566" "Saint-Geoire-en-Valdaine, PLAMPALAIS" [45.45726,5.6323] 10401 "1000590" "Saint-Geoire-en-Valdaine, LAMBERTIERE" [45.451297779865804,5.632716264303727]
327 "TPV_77_2" "1000562-1003457" 10852 "1000932" "Voreppe, LOUIS ARMAND" [45.306419778926234,5.614515742348389] 10851 "1002320" "Voreppe, RADIALL" [45.30773676510138,5.617529814917699]
92 "TPV_81_2" "1000764-1003442" 13257 "1001488" "Saint-Blaise-du-Buis, MAIRIE" [45.37654399743456,5.51699344513675] 13256 "1000476" "Saint-Blaise-du-Buis, RTE DE LA MURETTE" [45.37833597696442,5.5209521833360204]
114 "TPV_81_2" "1000759-1003439" 13205 "1001488" "Saint-Blaise-du-Buis, MAIRIE" [45.37654399743456,5.51699344513675] 13204 "1000476" "Saint-Blaise-du-Buis, RTE DE LA MURETTE" [45.37833597696442,5.5209521833360204]
213 "TPV_518_2" "1000414-1001855" 8841 "1000056" "La Buisse, LE PANSU" [45.34178354077886,5.606101815649903] 8840 "1000050" "La Buisse, CHEMIN DU GAY" [45.33181197437888,5.60747080392936]
537 "TPV_518_3" "1000416-1001861" 8867 "1000056" "La Buisse, LE PANSU" [45.34178354077886,5.606101815649903] 8866 "1000050" "La Buisse, CHEMIN DU GAY" [45.33178,5.60757]
big_gap_in_service INFO 36

big_gap_in_service

A service has a gap of more than 13 days between active service dates.

You can see more about this notice here.

serviceId (?) The service_id that has the gap. gapStartDate (?) The first day of the gap. gapEndDate (?) The last day of the gap. gapDurationDays (?) The number of days in the gap.
"287" "2026-07-03" "2026-08-17" 44
"290" "2025-10-17" "2025-11-03" 16
"290" "2025-12-19" "2026-01-05" 16
"290" "2026-02-06" "2026-02-23" 16
"290" "2026-04-03" "2026-04-20" 16
"290" "2026-07-03" "2026-09-01" 59
"290" "2026-10-16" "2026-11-03" 17
"291" "2025-10-15" "2025-11-05" 20
"291" "2025-12-17" "2026-01-07" 20
"291" "2026-02-04" "2026-02-25" 20
"291" "2026-04-01" "2026-04-22" 20
"291" "2026-07-01" "2026-09-02" 62
"291" "2026-10-14" "2026-11-04" 20
"292" "2025-10-17" "2025-11-03" 16
"292" "2025-12-19" "2026-01-05" 16
"292" "2026-02-06" "2026-02-23" 16
"292" "2026-04-03" "2026-04-20" 16
"292" "2026-07-03" "2026-09-01" 59
"292" "2026-10-16" "2026-11-03" 17
"294" "2026-07-04" "2026-08-17" 43
"295" "2026-07-03" "2026-08-17" 44
"299" "2025-10-17" "2025-11-03" 16
"299" "2025-12-19" "2026-01-05" 16
"299" "2026-02-06" "2026-02-23" 16
"299" "2026-04-03" "2026-04-20" 16
"299" "2026-07-03" "2026-09-01" 59
"299" "2026-10-16" "2026-11-03" 17
"300" "2026-07-03" "2026-08-17" 44
"302" "2026-02-04" "2026-02-25" 20
"302" "2026-04-01" "2026-04-22" 20
"302" "2026-07-01" "2026-09-02" 62
"302" "2026-10-14" "2026-11-04" 20
"303" "2026-02-06" "2026-02-23" 16
"303" "2026-04-03" "2026-04-20" 16
"303" "2026-07-03" "2026-09-01" 59
"303" "2026-10-16" "2026-11-03" 17
trip_headsign_matches_intermediate_stop INFO 1

trip_headsign_matches_intermediate_stop

Trip headsign matches the name of an intermediate stop, not the last stop.

The trip_headsign matches the stop_name of a stop that is not the last stop of the trip. This may confuse passengers boarding after that stop, since the headsign suggests the vehicle is heading to a stop it has already passed.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record in `trips.txt`. tripId (?) The id of the trip with the problematic headsign. tripHeadsign (?) The headsign value that matches an intermediate stop name. stopId1 (?) The id of the intermediate stop whose name matches the headsign. stopSequence (?) The stop_sequence value of the intermediate stop that matches the headsign. stopId2 (?) The id of the actual last stop of the trip.
255 "1000142-1000546" "Réaumont, BOURG ECOLE" "1000384" 3 "1000384"
unknown_column INFO 1

unknown_column

A column name is unknown.

You can see more about this notice here.

filename (?) The name of the faulty file. fieldName (?) The name of the unknown column. index (?) The index of the faulty column.
"feed_info.txt" "feed_id" 4
unsorted_stop_times INFO 2

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.

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.
"1000488-1002786" 514 13672
"1000488-1002785" 513 13669