GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 5.0.1 at 2024-06-09T21:43:55Z,
for the dataset file:///tmp/1_in.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Mobilités M - Transports du Pays Voironnais
Publisher URL:
https://www.mobilites-m.fr/
Feed Language:
French

Files included


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

Counts


  • Agencies: 1
  • Blocks: 1
  • Routes: 94
  • Shapes: 209
  • Stops: 1312
  • Trips: 894

GTFS Features included (?) GTFS features provide a standardized vocabulary to define and describe features that are officially adopted in GTFS.


Fares V1ShapesFeed InformationRoute ColorsHeadsignsWheelchair AccessibilityBikes AllowanceLocation Types

Specification Compliance report

1377 notices reported (479 errors, 897 warnings, 1 infos)

Notice Code Severity Total
decreasing_shape_distance ERROR 479

decreasing_shape_distance

Decreasing shape_dist_traveled in shapes.txt.

When sorted by shape.shape_pt_sequence, two consecutive shape points must not have decreasing values for shape_dist_traveled.

You can see more about this notice here.

Only the first 50 of 479 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_GA75_1" 46641 9429.37 168 46642 8830.26 169
"TPV_BE34_4" 19077 8870.96 214 19078 8858.42 215
"TPV_BE34_4" 19078 8858.42 215 19079 8827.68 216
"TPV_BE34_4" 19079 8827.68 216 19080 8820.75 217
"TPV_BE34_4" 19080 8820.75 217 19081 8812.64 218
"TPV_BE34_4" 19081 8812.64 218 19082 8800.41 219
"TPV_BE34_4" 19082 8800.41 219 19083 8771.52 220
"TPV_BE34_4" 19083 8771.52 220 19084 8763.73 221
"TPV_BE34_4" 19084 8763.73 221 19085 8754.88 222
"TPV_BE34_4" 19085 8754.88 222 19086 8743.33 223
"TPV_BE34_4" 19086 8743.33 223 19087 8733.37 224
"TPV_BE34_4" 19087 8733.37 224 19088 8724.05 225
"TPV_BE34_4" 19088 8724.05 225 19089 8705.57 226
"TPV_BE34_4" 19089 8705.57 226 19090 8683.5 227
"TPV_BE34_4" 19090 8683.5 227 19091 8672.09 228
"TPV_BE34_4" 19091 8672.09 228 19092 8660.71 229
"TPV_BE34_4" 19092 8660.71 229 19093 8581.31 230
"TPV_BE34_4" 19093 8581.31 230 19094 8564.42 231
"TPV_BE34_4" 19094 8564.42 231 19095 8549.45 232
"TPV_BE34_4" 19095 8549.45 232 19096 8542.73 233
"TPV_BE34_4" 19096 8542.73 233 19097 8534.41 234
"TPV_BE34_4" 19097 8534.41 234 19098 8516.35 235
"TPV_BE34_4" 19098 8516.35 235 19099 8506.59 236
"TPV_BE34_4" 19099 8506.59 236 19100 8475.47 237
"TPV_BE34_4" 19100 8475.47 237 19101 8445.29 238
"TPV_BE34_4" 19101 8445.29 238 19102 8416.92 239
"TPV_BE34_4" 19102 8416.92 239 19103 8366.72 240
"TPV_BE34_4" 19103 8366.72 240 19104 8327.92 241
"TPV_BE34_4" 19104 8327.92 241 19105 8306.1 242
"TPV_BE34_4" 19105 8306.1 242 19106 8265.32 243
"TPV_BE34_4" 19106 8265.32 243 19107 8238.66 244
"TPV_BE34_4" 19107 8238.66 244 19108 8217.38 245
"TPV_BE34_4" 19108 8217.38 245 19109 8170.63 246
"TPV_BE34_4" 19109 8170.63 246 19110 8151.39 247
"TPV_BE34_4" 19110 8151.39 247 19111 8124.41 248
"TPV_BE34_4" 19111 8124.41 248 19112 8103.96 249
"TPV_BE34_4" 19112 8103.96 249 19113 8070.42 250
"TPV_BE34_4" 19113 8070.42 250 19114 8020.4 251
"TPV_BE34_4" 19114 8020.4 251 19115 7967.25 252
"TPV_BE34_4" 19115 7967.25 252 19116 7938.05 253
"TPV_BE34_4" 19116 7938.05 253 19117 7891.18 254
"TPV_BE34_4" 19117 7891.18 254 19118 7836.77 255
"TPV_BE34_4" 19118 7836.77 255 19119 7810.52 256
"TPV_BE34_4" 19119 7810.52 256 19120 7792.95 257
"TPV_BE34_4" 19120 7792.95 257 19121 7756.24 258
"TPV_BE34_4" 19350 19297.87 487 19351 19284.98 488
"TPV_BE34_4" 19372 21401.48 509 19373 2291.09 510
"TPV_BE34_4" 19386 22718.7 523 19387 3564.53 524
"TPV_BE34_4" 19396 22927.91 533 19397 3846.3 534
"TPV_BE34_1" 19657 8880.6 212 19658 8868.07 213
equal_shape_distance_same_coordinates WARNING 783

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 783 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_F_4" 70450 2.92 3 70449 2.92 2
"TPV_F_4" 70454 36.62 7 70453 36.62 6
"TPV_F_4" 70457 128.39 10 70456 128.39 9
"TPV_F_4" 70459 154.94 12 70458 154.94 11
"TPV_F_4" 70462 192.71 15 70461 192.71 14
"TPV_F_4" 70466 324.53 19 70465 324.53 18
"TPV_F_4" 70472 497.19 25 70471 497.19 24
"TPV_F_4" 70475 516.21 28 70474 516.21 27
"TPV_F_4" 70477 531.64 30 70476 531.64 29
"TPV_F_4" 70481 549.92 34 70480 549.92 33
"TPV_F_4" 70486 644.12 39 70485 644.12 38
"TPV_F_4" 70492 729.55 45 70491 729.55 44
"TPV_F_4" 70498 802.8 51 70497 802.8 50
"TPV_F_4" 70503 873.98 56 70502 873.98 55
"TPV_F_4" 70505 935.75 58 70504 935.75 57
"TPV_F_4" 70507 958.65 60 70506 958.65 59
"TPV_F_4" 70512 1053.09 65 70511 1053.09 64
"TPV_F_4" 70515 1178.7 68 70514 1178.7 67
"TPV_F_4" 70521 1346.0 74 70520 1346.0 73
"TPV_F_4" 70524 1373.47 77 70523 1373.47 76
"TPV_F_4" 70529 1423.61 82 70528 1423.61 81
"TPV_F_4" 70541 1787.95 94 70540 1787.95 93
"TPV_F_4" 70549 1966.08 102 70548 1966.08 101
"TPV_F_4" 70563 2459.61 116 70562 2459.61 115
"TPV_F_4" 70565 2481.97 118 70564 2481.97 117
"TPV_F_4" 70580 2676.62 133 70579 2676.62 132
"TPV_F_4" 70583 2767.34 136 70582 2767.34 135
"TPV_F_4" 70585 2841.21 138 70584 2841.21 137
"TPV_F_4" 70588 2966.99 141 70587 2966.99 140
"TPV_F_4" 70592 3040.99 145 70591 3040.99 144
"TPV_F_4" 70594 3070.73 147 70593 3070.73 146
"TPV_F_4" 70601 3207.77 154 70600 3207.77 153
"TPV_F_4" 70611 3364.02 164 70610 3364.02 163
"TPV_F_4" 70614 3380.05 167 70613 3380.05 166
"TPV_F_4" 70618 3398.09 171 70617 3398.09 170
"TPV_F_4" 70621 3446.01 174 70620 3446.01 173
"TPV_F_4" 70625 3596.85 178 70624 3596.85 177
"TPV_F_4" 70628 3683.97 181 70627 3683.97 180
"TPV_F_4" 70631 3816.01 184 70630 3816.01 183
"TPV_F_4" 70635 3966.9 188 70634 3966.9 187
"TPV_F_4" 70637 4001.92 190 70636 4001.92 189
"TPV_F_4" 70640 4040.01 193 70639 4040.01 192
"TPV_F_4" 70662 5094.58 215 70661 5094.58 214
"TPV_F_4" 70677 5508.33 230 70676 5508.33 229
"TPV_F_4" 70680 5781.35 233 70679 5781.35 232
"TPV_F_4" 70686 6022.37 239 70685 6022.37 238
"TPV_F_4" 70692 6187.08 245 70691 6187.08 244
"TPV_F_4" 70698 6361.95 251 70697 6361.95 250
"TPV_F_4" 70701 6467.51 254 70700 6467.51 253
"TPV_F_4" 70707 6567.34 260 70706 6567.34 259
expired_calendar WARNING 2

expired_calendar

Dataset should not contain date ranges for services that have already expired.

This warning takes into account the calendar_dates.txt file as well as the calendar.txt file.

You can see more about this notice here.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
13 "163"
11 "165"
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_column WARNING 1

missing_recommended_column

A recommended column is missing in the input file.

You can see more about this notice here.

filename (?) The name of the faulty file. fieldName (?) The name of the missing column.
"stop_times.txt" "timepoint"
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 95

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 95 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" "TULLINS GOUY - CAMILLE DESMOULINS" 21
"routes.txt" "route_long_name" "LE PIN ST CHRISTOPHE - CHIRENS COLLEGE" 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 MALADIERE - VOIRON GARE SUD" 36
"routes.txt" "route_long_name" "VOIRON GARE NORD - PALADRU VILLAGE" 37
"routes.txt" "route_long_name" "VOIRON GARE SUD - VOIRON LA MARTELIERE" 38
"routes.txt" "route_long_name" "POMMIERS RD 520 VILLAGE - VOREPPE MAIRIE" 39
"routes.txt" "route_long_name" "LA BUISSE GIRATOIRE - VOREPPE L ARMAND" 40
"routes.txt" "route_long_name" "LA BUISSE ECOLE - COUBLEVIE PLAN MENU" 41
"routes.txt" "route_long_name" "LA BUISSE AFIPH - COUBLEVIE PLAN MENU" 42
"routes.txt" "route_long_name" "POMMIERS BARNIERS - COUBLEVIE PLAN MENU" 43
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - COUBLEVIE PLAN MENU" 44
"routes.txt" "route_long_name" "MIRIBEL LE VERNEY - COUBLEVIE PLAN MENU" 45
"routes.txt" "route_long_name" "CROSSEY GATELIERE - COUBLEVIE PLAN MENU" 46
"routes.txt" "route_long_name" "CROSSEY POMPIERS - COUBLEVIE PLAN MENU" 47
"routes.txt" "route_long_name" "CROSSEY TOLVON - COUBLEVIE PLAN MENU" 48
"routes.txt" "route_long_name" "VOIRON GARE NORD - COUBLEVIE PLAN MENU" 49
"routes.txt" "route_long_name" "REAUMONT BOURG -ST BLAISE MAIRIE" 50
"routes.txt" "route_long_name" "ST AUPRE GD VIVIER - ST AUPRE VILLAGE" 51
route_long_name_contains_short_name WARNING 1

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`.
"1000062" 52 "TAD-PMR" "TAD-PMR"
stop_too_far_from_shape WARNING 2

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.
689 "TPV_VO22_2" "1000412-1001849" 3598 "1000718" "Tullins, GARE SNCF" [45.30116000000001,5.49037] 118.11341628774245
491 "TPV_VO51_4" "1000440-1001911" 3896 "1001724" "Voiron, LE VERDIN" [45.39632215674098,5.57000803851545] 165.7119984733778
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.
730 "TPV_CO21_4" "1000329-1001674" 1373 "1001672" "Tullins, COLLEGE CONDORCET" [45.29804,5.486649999999999] 1372 "1001694" "Tullins, ECOLE DESMOULINS" [45.29870729774339,5.485213523665933]
881 "TPV_TAD-W_1" "1000156-1000572" 3221 "1001020" "La Sure en Chartreuse, TENNIS" [45.318689944336406,5.664379054333386] 3220 "1001412" "La Sure en Chartreuse, COL DE LA PLACETTE" [45.33030517219248,5.658188146498817]
570 "TPV_PR11_2" "1000049-1000087" 2546 "1001016" "Saint-Blaise-du-Buis, CHATELARD" [45.36921157086809,5.508102198767905] 2545 "1000392" "Réaumont, LE MOURET" [45.36611619135197,5.514600318877142]
289 "TPV_PR11_1" "1000142-1000546" 2561 "1001420" "Réaumont, LE BAYARD" [45.37133356476975,5.526676435235017] 2560 "1000384" "Réaumont, BOURG ECOLE" [45.367,5.52622]
146 "TPV_TAD-G_1" "1000723-1003345" 3127 "1001160" "Charavines, MONTFOLLET" [45.42243163342226,5.503432861222031] 3126 "1001170" "Charavines, VIRAGE JANIN" [45.429349976255544,5.499960308551804]
715 "TPV_CO22_4" "1000337-1001698" 1406 "1001672" "Tullins, COLLEGE CONDORCET" [45.29804,5.486649999999999] 1405 "1001694" "Tullins, ECOLE DESMOULINS" [45.29870620289897,5.485218417850237]
22 "TPV_2_2" "1000091-1000302" 11252 "1001792" "Voiron, BD DU GUILLON" [45.3635,5.597200000000001] 11251 "1000828" "Voiron, RUE GUIMET" [45.36311682323829,5.598855059845219]
unexpected_enum_value WARNING 1

unexpected_enum_value

An enum has an unexpected value.

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row number of the faulty record. fieldName (?) The name of the field where the error occurred. fieldValue (?) Faulty value.
"routes.txt" 52 "route_type" 715
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