GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-05-05T03:26:03Z,
for the dataset file:///shared/keolis_3aa28ec4.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Orléans Express
Feed Email:
N/A
Feed Language:
French
Feed Start Date:
2026-05-01
Feed End Date:
2026-06-01

Files included


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

Counts


  • Agencies: 2
  • Blocks: 0
  • Routes: 23
  • Shapes: 0
  • Stops: 126
  • Trips: 102

Specification Compliance report

17 notices reported (4 errors, 13 warnings, 0 infos)

Notice Code Severity Total
foreign_key_violation ERROR 4

foreign_key_violation

Wrong foreign key.

A foreign key references the primary key of another file. A foreign key violation means that the foreign key referenced from a given row (the child file) cannot be found in the corresponding file (the parent file). The Foreign keys are defined in the specification under "Type" for each file.

You can see more about this notice here.

childFilename (?) The name of the file from which reference is made. childFieldName (?) The name of the field that makes reference. parentFilename (?) The name of the file that is referred to. parentFieldName (?) The name of the field that is referred to. fieldValue (?) The faulty record's value. csvRowNumber (?) The row of the faulty record.
"stop_times.txt" "stop_id" "stops.txt" "stop_id" "743" 135
"stop_times.txt" "stop_id" "stops.txt" "stop_id" "740" 140
"stop_times.txt" "stop_id" "stops.txt" "stop_id" "740" 143
"stop_times.txt" "stop_id" "stops.txt" "stop_id" "743" 148
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.
85 "14730" "20" 2146.2995241296494 214.62995241296494 482 481 "5028" "Château Richer" "18:15:00" 483 482 "1184" "Boischatel" "18:20:00"
85 "14730" "20" 887.7153290412566 236.7240877443351 483 482 "1184" "Boischatel" "18:20:00" 484 483 "207" "Québec (Sainte-Foy)" "18:35:00"
86 "14731" "21" 178.46413061860545 17.846413061860545 497 496 "1075" "Clarke City" "19:40:00" 498 497 "726" "Sept-Îles" "19:45:00"
84 "14729" "20" 1261.5501731237093 231.2841984060134 425 424 "203" "Québec (centre-ville)" "10:00:00" 426 425 "1184" "Boischatel" "10:10:00"
84 "14729" "20" 1204.677959143067 220.85762584289563 426 425 "1184" "Boischatel" "10:10:00" 427 426 "5027" "L’Ange Gardien" "10:20:00"
fast_travel_between_far_stops WARNING 3

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.
85 "14730" "20" 2146.2995241296494 214.62995241296494 482 481 "5028" "Château Richer" "18:15:00" 483 482 "1184" "Boischatel" "18:20:00"
86 "14731" "21" 178.46413061860545 17.846413061860545 497 496 "1075" "Clarke City" "19:40:00" 498 497 "726" "Sept-Îles" "19:45:00"
84 "14729" "20" 1261.5501731237093 231.2841984060134 425 424 "203" "Québec (centre-ville)" "10:00:00" 426 425 "1184" "Boischatel" "10:10:00"
feed_expiration_date30_days WARNING 2

feed_expiration_date30_days

Dataset should cover at least the next 30 days of service.

At any time, the GTFS dataset should cover at least the next 30 days of service, and ideally for as long as the operator is confident that the schedule will continue to be operated.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. currentDate (?) Current date (YYYYMMDD format). feedEndDate (?) Feed end date (YYYYMMDD format). suggestedExpirationDate (?) Suggested expiration date (YYYYMMDD format).
2 "20260505" "20260601" "20260604"
3 "20260505" "20260601" "20260604"
missing_feed_contact_email_and_url WARNING 2

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
3
more_than_one_entity WARNING 1

more_than_one_entity

More than one row in CSV.

The file is expected to have a single entity but has more (e.g., "feed_info.txt").

You can see more about this notice here.

filename (?) Name of the faulty file. entityCount (?) Number of occurrences.
"feed_info.txt" 2