GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 5.0.1 at 2024-06-17T13:49:09Z,
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:
KEOLIS ARRAS
Publisher URL:
https://www.bus-artis.fr
Feed Language:
French
Feed Start Date:
2024-05-25
Feed End Date:
2024-09-01

Files included


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

Counts


  • Agencies: 1
  • Blocks: 1
  • Routes: 67
  • Shapes: 0
  • Stops: 1223
  • Trips: 3557

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


Feed InformationRoute ColorsHeadsignsWheelchair AccessibilityLocation Types

Specification Compliance report

77703 notices reported (188 errors, 77515 warnings, 0 infos)

Notice Code Severity Total
decreasing_or_equal_stop_time_distance ERROR 177

decreasing_or_equal_stop_time_distance

Decreasing or equal shape_dist_traveled in stop_times.txt.

When sorted by stop_times.stop_sequence, two consecutive entries in stop_times.txt should have increasing distance, based on the field shape_dist_traveled. If the values are equal, this is considered as an error.

You can see more about this notice here.

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

tripId (?) The id of the faulty trip. stopId (?) The id of the faulty stop. csvRowNumber (?) The row number from `stop_times.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. stopSequence (?) The faulty record's `stop_times.stop_sequence`. prevCsvRowNumber (?) The row number from `stop_times.txt` of the previous stop time. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous stop time. prevStopSequence (?) The previous record's `stop_times.stop_sequence`.
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AFAM02" 41195 1.0 3 41194 1.0 2
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AGBRA02" 41196 1.0 4 41195 1.0 3
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CHVE02" 41197 1.0 5 41196 1.0 4
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CRES02" 41198 1.0 6 41197 1.0 5
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "LIB02" 41199 1.0 7 41198 1.0 6
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "JMA02" 41202 3.0 10 41201 3.0 9
"138947{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "DEL02" 41203 3.0 11 41202 3.0 10
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "AFAM02" 42025 1.0 3 42024 1.0 2
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "AGBRA02" 42026 1.0 4 42025 1.0 3
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "CHVE02" 42027 1.0 5 42026 1.0 4
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "CRES02" 42028 1.0 6 42027 1.0 5
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "LIB02" 42029 1.0 7 42028 1.0 6
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "JMA02" 42032 3.0 10 42031 3.0 9
"139020{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "DEL02" 42033 3.0 11 42032 3.0 10
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AFAM02" 41228 1.0 3 41227 1.0 2
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AGBRA02" 41229 1.0 4 41228 1.0 3
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CHVE02" 41230 1.0 5 41229 1.0 4
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CRES02" 41231 1.0 6 41230 1.0 5
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "LIB02" 41232 1.0 7 41231 1.0 6
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "JMA02" 41235 3.0 10 41234 3.0 9
"138950{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "DEL02" 41236 3.0 11 41235 3.0 10
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AFAM02" 41162 1.0 3 41161 1.0 2
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AGBRA02" 41163 1.0 4 41162 1.0 3
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CHVE02" 41164 1.0 5 41163 1.0 4
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CRES02" 41165 1.0 6 41164 1.0 5
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "LIB02" 41166 1.0 7 41165 1.0 6
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "JMA02" 41169 3.0 10 41168 3.0 9
"138944{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "DEL02" 41170 3.0 11 41169 3.0 10
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AFAM02" 41151 1.0 3 41150 1.0 2
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "AGBRA02" 41152 1.0 4 41151 1.0 3
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CHVE02" 41153 1.0 5 41152 1.0 4
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "CRES02" 41154 1.0 6 41153 1.0 5
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "LIB02" 41155 1.0 7 41154 1.0 6
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "JMA02" 41158 3.0 10 41157 3.0 9
"138943{TAD8_1}-Septembre 2023 - TAD PS_10_LMWJVS" "DEL02" 41159 3.0 11 41158 3.0 10
"139044{TAC_1}-Septembre 2023 - TAD ETER_10_DF" "ADH02" 42247 0.0 2 42246 0.0 1
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "AFAM02" 42014 1.0 3 42013 1.0 2
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "AGBRA02" 42015 1.0 4 42014 1.0 3
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "CHVE02" 42016 1.0 5 42015 1.0 4
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "CRES02" 42017 1.0 6 42016 1.0 5
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "LIB02" 42018 1.0 7 42017 1.0 6
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "JMA02" 42021 3.0 10 42020 3.0 9
"139019{TAD8_1}-Septembre 2023 - TAD ETER_10_LMWJVS" "DEL02" 42022 3.0 11 42021 3.0 10
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "AFAM02" 41349 1.0 3 41348 1.0 2
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "AGBRA02" 41350 1.0 4 41349 1.0 3
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "CHVE02" 41351 1.0 5 41350 1.0 4
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "CRES02" 41352 1.0 6 41351 1.0 5
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "LIB02" 41353 1.0 7 41352 1.0 6
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "JMA02" 41356 3.0 10 41355 3.0 9
"138961{TAD8_1}-Septembre 2023 - TAD VS_10_LMWJVS" "DEL02" 41357 3.0 11 41356 3.0 10
point_near_origin ERROR 10

point_near_origin

A point is too close to origin (0, 0).

You can see more about this notice here.

filename (?) The name of the affected GTFS file. csvRowNumber (?) The row of the faulty row. entityId (?) The id of the faulty entity. latFieldName (?) The name of the field that uses latitude value. latFieldValue (?) The latitude of the faulty row. lonFieldName (?) The name of the field that uses longitude value. lonFieldValue (?) The longitude of the faulty row
"stops.txt" 25 "ARCOM@AFAM" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 27 "ARCOM@AGBRA" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 66 "ARCOM@BEF" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 106 "ARCOM@CCA" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 107 "ARCOM@CCB" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 146 "ARCOM@CRU" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 277 "ARCOM@MOU" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 314 "ARCOM@PCU" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 374 "ARCOM@SAM" "stop_lat" 0.0 "stop_lon" 0.0
"stops.txt" 413 "ARCOM@VAR" "stop_lat" 0.0 "stop_lon" 0.0
stop_time_with_arrival_before_previous_departure_time ERROR 1

stop_time_with_arrival_before_previous_departure_time

Backwards time travel between stops in stop_times.txt

For a given trip_id, the arrival_time of (n+1)-th stoptime in sequence must not precede the departure_time of n-th stoptime in sequence in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. prevCsvRowNumber (?) The row of the previous stop time. tripId (?) The trip_id associated to the faulty record. arrivalTime (?) Arrival time at the faulty record. departureTime (?) Departure time at the previous stop time.
59325 59324 "141107{C40_1}-Septembre 2023 Lot 100 - PS_2_W" "12:21:00" "12:22:00"
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 77486

missing_timepoint_value

stop_times.timepoint value is missing for a record.

Even though the column timepoint is optional in stop_times.txt according to the specification, stop_times.timepoint should not be empty when provided.

You can see more about this notice here.

Only the first 50 of 77486 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 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 1
3 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 2
4 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 3
5 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 4
6 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 5
7 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 6
8 "101871{C29_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 7
9 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 1
10 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 2
11 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 3
12 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 4
13 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 5
14 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 6
15 "101872{C29_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 7
16 "101873{C29_1}-Septembre 2023 Lot 100 - PS_2_W" 1
17 "101873{C29_1}-Septembre 2023 Lot 100 - PS_2_W" 2
18 "101873{C29_1}-Septembre 2023 Lot 100 - PS_2_W" 3
19 "101873{C29_1}-Septembre 2023 Lot 100 - PS_2_W" 4
20 "101873{C29_1}-Septembre 2023 Lot 100 - PS_2_W" 5
21 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 1
22 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 2
23 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 3
24 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 4
25 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 5
26 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 6
27 "101874{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 7
28 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 1
29 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 2
30 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 3
31 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 4
32 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 5
33 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 6
34 "101875{C30_1}-Septembre 2023 Lot 100 - PS_2_LMJV" 7
35 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 1
36 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 2
37 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 3
38 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 4
39 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 5
40 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 6
41 "101876{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 7
42 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 1
43 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 2
44 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 3
45 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 4
46 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 5
47 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 6
48 "101877{C30_1}-Septembre 2023 Lot 100 - PS_2_W" 7
49 "101878{C30_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 1
50 "101878{C30_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 2
51 "101878{C30_1}-Septembre 2023 Lot 100 - PS_2_LMWJV" 3
mixed_case_recommended_field WARNING 5

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.

filename (?) Name of the faulty file. fieldName (?) Name of the faulty field. fieldValue (?) Faulty value. csvRowNumber (?) The row number of the faulty record.
"stops.txt" "stop_name" "8 mai" 7
"stops.txt" "stop_name" "8 mai" 449
"stops.txt" "stop_name" "8 mai" 450
"stops.txt" "stop_name" "8 mai" 839
"routes.txt" "route_desc" "version définitive réseau septembre 2023" 18
route_color_contrast WARNING 8

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.
"C31_1" 23 "#8000FF" "#000000"
"C32_1" 24 "#8000FF" "#000000"
"C33_1" 25 "#8000FF" "#000000"
"C34_2" 26 "#8000FF" "#000000"
"C35_1" 27 "#AE00AE" "#000000"
"C37_1" 29 "#A800A8" "#000000"
"C39_2" 31 "#AE00AE" "#000000"
"L13_23" 48 "#8000FF" "#000000"
route_long_name_contains_short_name WARNING 15

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`.
"C28_2" 19 "C28" "C28 Boiry St Martin"
"C29_1" 20 "C29" "C29 Boyelle"
"C30_1" 22 "C30" "C30 Neuville St Vaast"
"C31_1" 23 "C31" "C31 RPI Mercatel"
"C32_1" 24 "C32" "C32 RPI Mont St Eloi"
"C33_1" 25 "C33" "C33 RPI Roclincourt"
"C34_2" 26 "C34" "C34 RPI Farbus - Vimy"
"C35_1" 27 "C35" "C35 Mont St Eloi"
"C36_1" 28 "C36" "C36 Mont St Eloi"
"C37_1" 29 "C37" "C37 Acq"
"C38_2" 30 "C38" "C38 Etrun"
"C39_2" 31 "C39" "C39 Acq"
"C40_1" 32 "C40" "C40 Mont St Eloi"
"C41_1" 33 "C41" "C41 Etrun"
"C7_2" 38 "C7" "C7 Mitterand"