GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2025-12-12T21:57:41Z,
for the dataset file:///shared/tpv.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: 92
  • Shapes: 204
  • Stops: 1216
  • Trips: 892

Specification Compliance report

661 notices reported (0 errors, 660 warnings, 1 infos)

Notice Code Severity Total
equal_shape_distance_same_coordinates WARNING 476

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 476 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" 24870 6453.12 49 24869 6453.12 48
"TPV_39_4" 24891 8139.86 70 24890 8139.86 69
"TPV_39_4" 24898 9473.13 77 24897 9473.13 76
"TPV_39_4" 24913 11490.78 92 24912 11490.78 91
"TPV_39_4" 24915 11512.63 94 24914 11512.63 93
"TPV_39_1" 16515 66.73 4 16514 66.73 3
"TPV_39_1" 16519 242.04 8 16518 242.04 7
"TPV_39_1" 16521 266.06 10 16520 266.06 9
"TPV_39_1" 16528 709.08 17 16527 709.08 16
"TPV_39_1" 16532 798.34 21 16531 798.34 20
"TPV_39_1" 16534 804.21 23 16533 804.21 22
"TPV_39_1" 16536 881.3 25 16535 881.3 24
"TPV_39_1" 16538 909.04 27 16537 909.04 26
"TPV_39_1" 16549 1378.73 38 16548 1378.73 37
"TPV_39_1" 16562 1750.63 51 16561 1750.63 50
"TPV_39_1" 16564 1810.47 53 16563 1810.47 52
"TPV_39_1" 16571 1859.13 60 16570 1859.13 59
"TPV_39_1" 16574 1915.51 63 16573 1915.51 62
"TPV_39_1" 16582 2154.86 71 16581 2154.86 70
"TPV_39_1" 16587 2486.61 76 16586 2486.61 75
"TPV_39_1" 16593 2876.51 82 16592 2876.51 81
"TPV_39_1" 16607 3590.16 96 16606 3590.16 95
"TPV_39_1" 16620 4246.07 109 16619 4246.07 108
"TPV_39_1" 16629 4483.29 118 16628 4483.29 117
"TPV_39_1" 16643 4878.51 132 16642 4878.51 131
"TPV_39_1" 16646 4924.67 135 16645 4924.67 134
"TPV_39_1" 16654 5155.76 143 16653 5155.76 142
"TPV_39_1" 16663 5546.78 152 16662 5546.78 151
"TPV_39_1" 16673 5772.45 162 16672 5772.45 161
"TPV_39_1" 16678 5850.04 167 16677 5850.04 166
"TPV_39_1" 16682 6025.22 171 16681 6025.22 170
"TPV_39_1" 16686 6134.65 175 16685 6134.65 174
"TPV_39_1" 16689 6226.08 178 16688 6226.08 177
"TPV_39_1" 16691 6237.64 180 16690 6237.64 179
"TPV_39_1" 16701 6594.23 190 16700 6594.23 189
"TPV_39_1" 16704 6690.04 193 16703 6690.04 192
"TPV_39_1" 16706 6718.71 195 16705 6718.71 194
"TPV_39_1" 16718 7021.22 207 16717 7021.22 206
"TPV_39_1" 16722 7167.83 211 16721 7167.83 210
"TPV_39_1" 16724 7179.66 213 16723 7179.66 212
"TPV_39_1" 16727 7220.3 216 16726 7220.3 215
"TPV_39_1" 16730 7279.27 219 16729 7279.27 218
"TPV_39_1" 16733 7305.17 222 16732 7305.17 221
"TPV_39_1" 16735 7322.75 224 16734 7322.75 223
"TPV_39_1" 16741 7504.26 230 16740 7504.26 229
"TPV_39_1" 16746 7625.15 235 16745 7625.15 234
"TPV_39_1" 16750 7694.73 239 16749 7694.73 238
"TPV_39_1" 16756 7797.19 245 16755 7797.19 244
"TPV_39_1" 16758 7800.25 247 16757 7800.25 246
"TPV_39_1" 16764 7957.15 253 16763 7957.15 252
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 93

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 93 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" "MOIRANS BEGHIN - LE FONTANIL F. DOLTO" 12
"routes.txt" "route_long_name" "MERLAS PICOUDIERE - CHIRENS COLLEGE" 13
"routes.txt" "route_long_name" "ST SULPICE RIVOIRES - CHIRENS COLLEGE" 14
"routes.txt" "route_long_name" "LE PIN LES ALLEX - CHIRENS COLLEGE" 15
"routes.txt" "route_long_name" "PALADRU TROIS CHENES - CHIRENS COLLEGE" 16
"routes.txt" "route_long_name" "MONTFERRAT LE VERNEY - CHIRENS COLLEGE" 17
"routes.txt" "route_long_name" "CHARAVINES MONTFOLLET - CHIRENS COLLEGE" 18
"routes.txt" "route_long_name" "CHARAVINES PLACE MARCHE CHIRENS COLLEGE" 19
"routes.txt" "route_long_name" "BILIEU PETIT BILIEU - CHIRENS COLLEGE" 20
"routes.txt" "route_long_name" "LE PIN ST CHRISTOPHE - CHIRENS COLLEGE" 21
"routes.txt" "route_long_name" "TULLINS GOUY - CAMILLE DESMOULINS" 22
"routes.txt" "route_long_name" "TULLINS ST J. CHEPY - COLLEGE CONDORCET" 23
"routes.txt" "route_long_name" "MIRIBEL EGLISE - VOIRON GARE SUD" 24
"routes.txt" "route_long_name" "ST BLAISE RAVIGNHOUSE - RIVES DESNOS" 25
"routes.txt" "route_long_name" "REAUMONT H. FERROVIAIRE - RIVES DESNOS" 26
"routes.txt" "route_long_name" "REAUMONT LE BESSEY - RIVES DESNOS" 27
"routes.txt" "route_long_name" "ST GEOIRE COTAGON - VOIRON GARE NORD" 28
"routes.txt" "route_long_name" "MONTFERRAT VILLAGE - VOIRON GARE NORD" 29
"routes.txt" "route_long_name" "LA MURETTE VILLAGE - VOIRON LA GARENNE" 30
"routes.txt" "route_long_name" "ST CASSIEN MALOZA - VOIRON LA GARENNE" 31
"routes.txt" "route_long_name" "MOIRANS PETIT CRIEL - LA GARENNE" 32
"routes.txt" "route_long_name" "VOIRON LAVOIR CRIEL - LA GARENNE" 33
"routes.txt" "route_long_name" "LA MURETTE COURATIERE - VOIRON GARENNE" 34
"routes.txt" "route_long_name" "VOIRON LES TUILIERES - VOIRON LA GARENNE" 35
"routes.txt" "route_long_name" "RIVES - VOIRON GARE SUD" 36
"routes.txt" "route_long_name" "VOIRON GARE SUD - VOIRON LA MARTELIERE" 37
"routes.txt" "route_long_name" "POMMIERS RD 520 VILLAGE - VOREPPE MAIRIE" 38
"routes.txt" "route_long_name" "LA BUISSE GIRATOIRE - VOREPPE L ARMAND" 39
"routes.txt" "route_long_name" "LA BUISSE ECOLE - COUBLEVIE PLAN MENU" 40
"routes.txt" "route_long_name" "LA BUISSE AFIPH - COUBLEVIE PLAN MENU" 41
"routes.txt" "route_long_name" "POMMIERS BARNIERS - COUBLEVIE PLAN MENU" 42
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - COUBLEVIE PLAN MENU" 43
"routes.txt" "route_long_name" "MIRIBEL LE VERNEY - COUBLEVIE PLAN MENU" 44
"routes.txt" "route_long_name" "CROSSEY GATELIERE - COUBLEVIE PLAN MENU" 45
"routes.txt" "route_long_name" "CROSSEY POMPIERS - COUBLEVIE PLAN MENU" 46
"routes.txt" "route_long_name" "CROSSEY TOLVON - COUBLEVIE PLAN MENU" 47
"routes.txt" "route_long_name" "VOIRON GARE NORD - COUBLEVIE PLAN MENU" 48
"routes.txt" "route_long_name" "REAUMONT BOURG -ST BLAISE MAIRIE" 49
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - ST AUPRE VILLAGE" 50
"routes.txt" "route_long_name" "MERLAS PICOUDIERE - ST GEOIRE PLAMPALAIS" 51
route_color_contrast WARNING 73

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.

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

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.
"10002" 3 "#FFFF80" "#FFFFFF"
"10003" 4 "#FFFF80" "#FFFFFF"
"10004" 5 "#FFFF80" "#FFFFFF"
"10005" 6 "#FFFF80" "#FFFFFF"
"10006" 7 "#FFFF80" "#FFFFFF"
"10007" 8 "#FFFF80" "#FFFFFF"
"10008" 9 "#FFFF80" "#FFFFFF"
"10009" 10 "#FFFF80" "#FFFFFF"
"10010" 11 "#FFFF80" "#FFFFFF"
"10011" 12 "#FFFF80" "#FFFFFF"
"10012" 13 "#FFFF80" "#FAFAFA"
"10013" 14 "#FFFF80" "#FFFFFF"
"10014" 15 "#FFFF80" "#FFFFFF"
"10015" 16 "#FFFF80" "#FFFFFF"
"10016" 17 "#FFFF80" "#FFFFFF"
"10017" 18 "#FFFF80" "#FFFFFF"
"10018" 19 "#FFFF80" "#FFFFFF"
"10019" 20 "#FFFF80" "#FFFFFF"
"10020" 21 "#FFFF80" "#FFFFFF"
"10021" 22 "#FFFF80" "#FFFFFF"
"10022" 23 "#FFFF80" "#FFFFFF"
"10024" 25 "#FFFF80" "#FFFFFF"
"10025" 26 "#FFFF80" "#FFFFFF"
"10026" 27 "#FFFF80" "#FFFFFF"
"10029" 30 "#FFFF80" "#FFFFFF"
"10030" 31 "#FFFF80" "#FFFFFF"
"10031" 32 "#FFFF80" "#FFFFFF"
"10032" 33 "#FFFF80" "#FFFFFF"
"10033" 34 "#FFFF80" "#FFFFFF"
"10034" 35 "#FFFF80" "#FFFFFF"
"10037" 37 "#FFFF80" "#FFFFFF"
"10038" 38 "#FFFF80" "#FFFFFF"
"10040" 40 "#FFFF80" "#FFFFFF"
"10041" 41 "#FFFF80" "#FFFFFF"
"10042" 42 "#FFFF80" "#FFFFFF"
"10043" 43 "#FFFF80" "#FFFFFF"
"10044" 44 "#FFFF80" "#FFFFFF"
"10045" 45 "#FFFF80" "#FFFFFF"
"10046" 46 "#FFFF80" "#FFFFFF"
"10047" 47 "#FFFF80" "#FFFFFF"
"10048" 48 "#FFFF80" "#FFFFFF"
"10049" 49 "#FFFF80" "#FFFFFF"
"10050" 50 "#FFFF80" "#FFFFFF"
"10051" 51 "#FFFF80" "#FFFFFF"
"10052" 52 "#FFFF80" "#FFFFFF"
"10053" 53 "#FFFF80" "#FFFFFF"
"10054" 54 "#FFFF80" "#FFFFFF"
"10055" 55 "#FFFF80" "#FFFFFF"
"10056" 56 "#FFFF80" "#FFFFFF"
"10065" 63 "#FFFF80" "#FFFFFF"
stop_too_far_from_shape WARNING 6

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.
523 "TPV_575_2" "1000147-1000553" 2711 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
88 "TPV_537_2" "1000098-1000425" 809 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
520 "TPV_511_2" "1000403-1001827" 3153 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
50 "TPV_511_3" "1000404-1001831" 3182 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
414 "TPV_512_2" "1000161-1000583" 3224 "1000410" "Rives, COLLEGE R DESNOS" [45.34939,5.50494] 196.8168804274687
28 "TPV_593_1" "1000228-1001204" 2575 "1000544" "Saint-Geoire-en-Valdaine, VILLAGE" [45.45513,5.636250000000001] 173.96760906918294
stops_match_shape_out_of_order WARNING 7

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.
359 "TPV_503_1" "1000156-1000572" 3010 "1001020" "La Sure en Chartreuse, TENNIS" [45.318689944336406,5.664379054333386] 3009 "1001412" "La Sure en Chartreuse, COL DE LA PLACETTE" [45.33030517219248,5.658188146498817]
76 "TPV_585_3" "1000337-1001698" 1405 "1001672" "Tullins, COLLEGE CONDORCET" [45.29804,5.486649999999999] 1404 "1001694" "Tullins, ECOLE DESMOULINS" [45.29801,5.485429999999999]
311 "TPV_593_2" "1000727-1003355" 2578 "1000950" "Saint-Geoire-en-Valdaine, LA COMBE" [45.45513059754709,5.636255975445429] 2577 "1000590" "Saint-Geoire-en-Valdaine, LAMBERTIERE" [45.451297779865804,5.632716264303727]
731 "TPV_593_2" "1000770-1003453" 2598 "1000566" "Saint-Geoire-en-Valdaine, PLAMPALAIS" [45.45726,5.6323] 2597 "1000590" "Saint-Geoire-en-Valdaine, LAMBERTIERE" [45.451297779865804,5.632716264303727]
672 "TPV_81_2" "1000759-1003439" 14679 "1001488" "Saint-Blaise-du-Buis, MAIRIE" [45.37654399743456,5.51699344513675] 14678 "1000476" "Saint-Blaise-du-Buis, RTE DE LA MURETTE" [45.37833597696442,5.5209521833360204]
62 "TPV_518_2" "1000414-1001855" 3401 "1000056" "La Buisse, LE PANSU" [45.34178354077886,5.606101815649903] 3400 "1000050" "La Buisse, CHEMIN DU GAY" [45.33181197437888,5.60747080392936]
553 "TPV_518_2" "1000416-1001861" 3427 "1000056" "La Buisse, LE PANSU" [45.34178354077886,5.606101815649903] 3426 "1000050" "La Buisse, CHEMIN DU GAY" [45.33181197437888,5.60747080392936]
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