GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-20T00:22:32Z,
for the dataset file:///shared/ouigo_acabb112.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. country_names.txt
  5. licences_and_sources.txt
  6. routes.txt
  7. stop_times.txt
  8. stops.txt
  9. transfers.txt
  10. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 11
  • Shapes: 0
  • Stops: 16
  • Trips: 68

Specification Compliance report

116 notices reported (0 errors, 111 warnings, 5 infos)

Notice Code Severity Total
fast_travel_between_consecutive_stops WARNING 5

fast_travel_between_consecutive_stops

A transit vehicle moves too fast between two consecutive stops.

The speed threshold depends on route type:

Route type Description Threshold, km/h
0 Light rail 100
1 Subway 150
2 Rail 500
3 Bus 150
4 Ferry 80
5 Cable tram 30
6 Aerial lift 50
7 Funicular 50
11 Trolleybus 150
12 Monorail 150
- Unknown 200

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
57 "56" "7" 221.15045554727757 117.94690962521472 165 4 "007160600" "ALBACETE" "21:49:00" 166 5 "007103208" "CUENCA FERNANDO ZOBEL" "22:20:00"
67 "66" "10" 202.19470221465377 117.94690962521472 216 4 "007160600" "ALBACETE" "08:42:00" 217 5 "007103208" "CUENCA FERNANDO ZOBEL" "09:16:00"
69 "68" "11" 214.44892659129948 117.94690962521472 230 4 "007103208" "CUENCA FERNANDO ZOBEL" "15:19:00" 231 5 "007160600" "ALBACETE" "15:51:00"
66 "65" "10" 202.19470221465377 117.94690962521472 208 4 "007160600" "ALBACETE" "08:42:00" 209 5 "007103208" "CUENCA FERNANDO ZOBEL" "09:16:00"
68 "67" "11" 214.44892659129948 117.94690962521472 224 4 "007103208" "CUENCA FERNANDO ZOBEL" "15:19:00" 225 5 "007160600" "ALBACETE" "15:51:00"
fast_travel_between_far_stops WARNING 5

fast_travel_between_far_stops

A transit vehicle moves too fast between two far stops.

Two stops are considered "far" if they are more than 10 km apart. This normally indicates a more serious problem than too fast travel between consecutive stops.

The speed threshold depends on route type and are the same as fast_travel_between_consecutive_stops.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the problematic trip. tripId (?) `trip_id` of the problematic trip. routeId (?) `route_id` of the problematic trip. speedKph (?) Travel speed (km/h). distanceKm (?) Distance between stops (km). csvRowNumber1 (?) The row number of the first stop time. stopSequence1 (?) `stop_sequence` of the first stop. stopId1 (?) `stop_id` of the first stop. stopName1 (?) `stop_name` of the first stop. departureTime1 (?) `departure_time` of the first stop. csvRowNumber2 (?) The row number of the second stop time. stopSequence2 (?) `stop_sequence` of the second stop. stopId2 (?) `stop_id` of the second stop. stopName2 (?) `stop_name` of the second stop. arrivalTime2 (?) `arrival_time` of the second stop.
57 "56" "7" 221.15045554727757 117.94690962521472 165 4 "007160600" "ALBACETE" "21:49:00" 166 5 "007103208" "CUENCA FERNANDO ZOBEL" "22:20:00"
67 "66" "10" 202.19470221465377 117.94690962521472 216 4 "007160600" "ALBACETE" "08:42:00" 217 5 "007103208" "CUENCA FERNANDO ZOBEL" "09:16:00"
69 "68" "11" 214.44892659129948 117.94690962521472 230 4 "007103208" "CUENCA FERNANDO ZOBEL" "15:19:00" 231 5 "007160600" "ALBACETE" "15:51:00"
66 "65" "10" 202.19470221465377 117.94690962521472 208 4 "007160600" "ALBACETE" "08:42:00" 209 5 "007103208" "CUENCA FERNANDO ZOBEL" "09:16:00"
68 "67" "11" 214.44892659129948 117.94690962521472 224 4 "007103208" "CUENCA FERNANDO ZOBEL" "15:19:00" 225 5 "007160600" "ALBACETE" "15:51:00"
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"
mixed_case_recommended_field WARNING 89

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 89 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" "MADRID-PUERTA DE ATOCHA" 2
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 3
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 4
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 5
"trips.txt" "trip_headsign" "SEVILLA-SANTA JUSTA" 6
"trips.txt" "trip_headsign" "SEVILLA-SANTA JUSTA" 7
"trips.txt" "trip_headsign" "SEVILLA-SANTA JUSTA" 8
"trips.txt" "trip_headsign" "SEVILLA-SANTA JUSTA" 9
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 10
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 11
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 12
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 13
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 14
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 15
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 16
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 17
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 18
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 19
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 20
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 21
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 22
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 23
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 24
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 25
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 26
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 27
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 28
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 29
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 30
"trips.txt" "trip_headsign" "SEVILLA-SANTA JUSTA" 31
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 32
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 33
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 34
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 35
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 36
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 37
"trips.txt" "trip_headsign" "MADRID-PUERTA DE ATOCHA" 38
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 39
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 40
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 41
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 42
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 43
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 44
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 45
"trips.txt" "trip_headsign" "MALAGA MARIA ZAMBRANO" 46
"trips.txt" "trip_headsign" "BARCELONA-SANTS" 47
"trips.txt" "trip_headsign" "MADRID-CHAMARTIN" 48
"trips.txt" "trip_headsign" "MADRID-CHAMARTIN" 49
"trips.txt" "trip_headsign" "MADRID-CHAMARTIN" 50
"trips.txt" "trip_headsign" "MADRID-CHAMARTIN" 51
unexpected_enum_value WARNING 11

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" 2 "route_type" 101
"routes.txt" 3 "route_type" 101
"routes.txt" 4 "route_type" 101
"routes.txt" 5 "route_type" 101
"routes.txt" 6 "route_type" 101
"routes.txt" 7 "route_type" 101
"routes.txt" 8 "route_type" 101
"routes.txt" 9 "route_type" 101
"routes.txt" 10 "route_type" 101
"routes.txt" 11 "route_type" 101
"routes.txt" 12 "route_type" 101
big_gap_in_service INFO 3

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.
"8" "2026-07-26" "2026-08-10" 14
"11" "2026-07-26" "2026-08-10" 14
"26" "2026-07-15" "2026-08-08" 23
unknown_file INFO 2

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"licences_and_sources.txt"
"country_names.txt"