GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-19T21:31:38Z,
for the dataset file:///shared/st-albert-transit_c8d5bc20.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
Edmonton Transit Service
Publisher URL:
http://www.takeets.com
Feed Email:
N/A
Feed Language:
English
Feed Start Date:
2021-03-15
Feed End Date:
2021-03-27

Files included


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

Counts


  • Agencies: 2
  • Blocks: 147
  • Routes: 42
  • Shapes: 162
  • Stops: 857
  • Trips: 3004

Specification Compliance report

3377 notices reported (350 errors, 13 warnings, 3014 infos)

Notice Code Severity Total
decreasing_or_equal_stop_time_distance ERROR 350

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 350 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`.
"19863976" "S6065" 22512 13533.2 37 22511 13533.2 36
"19863975" "S6065" 22450 13533.2 37 22449 13533.2 36
"19484303" "A0542" 66502 0.0 2 66501 0.0 1
"19484304" "A0542" 66504 0.0 2 66503 0.0 1
"19484301" "A0542" 66498 0.0 2 66497 0.0 1
"19484302" "A0542" 66500 0.0 2 66499 0.0 1
"19484300" "A0542" 66496 0.0 2 66495 0.0 1
"19484305" "A0542" 66506 0.0 2 66505 0.0 1
"19484306" "A0542" 66508 0.0 2 66507 0.0 1
"19863950" "S4000" 21909 9617.3 29 21908 9617.3 28
"19863949" "S4000" 21860 9617.3 29 21859 9617.3 28
"19863948" "S1002" 21784 3193.0 8 21783 3193.0 7
"19863947" "S1002" 21727 3193.0 8 21726 3193.0 7
"19863946" "S1002" 21670 3193.0 8 21669 3193.0 7
"19794434" "A0545" 46311 12895.2 24 46310 12895.2 23
"19794429" "A0545" 46245 12895.2 24 46244 12895.2 23
"19794421" "A0545" 46160 12895.2 24 46159 12895.2 23
"19794427" "A0538" 46202 4522.5 8 46201 4522.5 7
"19484314" "A0971" 66520 0.0 2 66519 0.0 1
"19484315" "A0971" 66522 0.0 2 66521 0.0 1
"19484312" "A0971" 66516 0.0 2 66515 0.0 1
"19484313" "A0971" 66518 0.0 2 66517 0.0 1
"19484311" "A0971" 66514 0.0 2 66513 0.0 1
"19484318" "A0971" 66528 0.0 2 66527 0.0 1
"19484319" "A0971" 66530 0.0 2 66529 0.0 1
"19484316" "A0971" 66524 0.0 2 66523 0.0 1
"19484317" "A0971" 66526 0.0 2 66525 0.0 1
"19794415" "A0545" 46037 12895.2 24 46036 12895.2 23
"19794416" "A0545" 46064 12895.2 24 46063 12895.2 23
"19794413" "A0538" 45978 4522.5 8 45977 4522.5 7
"19794414" "A0538" 45999 4522.5 8 45998 4522.5 7
"19484321" "A0971" 66534 0.0 2 66533 0.0 1
"19484320" "A0971" 66532 0.0 2 66531 0.0 1
"19794400" "A0538" 45759 4522.5 8 45758 4522.5 7
"19794401" "A0545" 45805 12895.2 24 45804 12895.2 23
"19794405" "A0538" 45852 4522.5 8 45851 4522.5 7
"19935279" "S1002" 58525 3193.0 8 58524 3193.0 7
"19935281" "S1002" 58639 3193.0 8 58638 3193.0 7
"19935282" "S1002" 58696 3193.0 8 58695 3193.0 7
"19935283" "S4000" 58772 9617.3 29 58771 9617.3 28
"19935284" "S4000" 58821 9617.3 29 58820 9617.3 28
"19935285" "S4000" 58870 9617.3 29 58869 9617.3 28
"19935286" "S4000" 58919 9617.3 29 58918 9617.3 28
"19935280" "S1002" 58582 3193.0 8 58581 3193.0 7
"19794460" "A0538" 46782 4522.5 8 46781 4522.5 7
"19794461" "A0545" 46828 12895.2 24 46827 12895.2 23
"19794468" "A0538" 46898 4522.5 8 46897 4522.5 7
"19794459" "A0538" 46753 4522.5 8 46752 4522.5 7
"19794441" "A0538" 46394 4522.5 8 46393 4522.5 7
"19794442" "A0538" 46415 4522.5 8 46414 4522.5 7
expired_calendar WARNING 9

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.
2 "Blocking-Saturday-4-SCT-MDW21-0000010"
8 "Blocking-Sunday-5-SCT-MDW21-0000001"
14 "Blocking-Weekday-28-STAT-MDW21-1111100"
43 "Blocking-Weekday-6-SCT-MDW21-1111100"
64 "Blocking-Weekday-7-SCT-MDW21-1111100"
65 "Blocking-Weekday-9-SCT-MDW21-1111100"
72 "StAT-Blk-Saturday-21-STAT-MDW21-0000010"
78 "StAT-Blk-Sunday-14-STAT-MDW21-0000001"
79 "StAT-Blk-Sunday-15-STAT-MDW21-0000001"
feed_expiration_date7_days WARNING 1

feed_expiration_date7_days

Dataset should be valid for at least the next 7 days.

The dataset expiration date defined in feed_info.txt is in seven days or less. At any time, the published GTFS dataset should be valid for at least the next 7 days.

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 "20260619" "20210327" "20260626"
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
mixed_case_recommended_field WARNING 1

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.
"routes.txt" "route_long_name" "ABJ SCHOOL" 18
trip_coverage_not_active_for_next7_days WARNING 1

trip_coverage_not_active_for_next7_days

Trips data should be valid for at least the next seven days.

This notice is triggered if the date range where a significant number of trips are running ends in less than 7 days.

You can see more about this notice here.

currentDate (?) Current date (YYYYMMDD format). serviceWindowStartDate (?) The start date of the majority service window. serviceWindowEndDate (?) The end date of the majority service window.
"20260619" "20210315" "20210423"
service_window_outside_feed_period INFO 9

service_window_outside_feed_period

A service window is not covered by the feed's validity period.

You can see more about this notice here.

serviceId (?) The service_id whose active window extends outside the feed validity period. serviceWindowStartDate (?) The first active date of the service window. serviceWindowEndDate (?) The last active date of the service window. daysBeforeFeedStart (?) Number of days the service window extends before feed_start_date (0 if none). daysAfterFeedEnd (?) Number of days the service window extends after feed_end_date (0 if none).
"StAT-Blk-Sunday-15-STAT-MDW21-0000001" "2021-03-14" "2021-04-18" 1 22
"Blocking-Weekday-7-SCT-MDW21-1111100" "2021-04-07" "2021-04-07" 0 11
"StAT-Blk-Sunday-14-STAT-MDW21-0000001" "2021-04-02" "2021-04-02" 0 6
"Blocking-Sunday-5-SCT-MDW21-0000001" "2021-03-14" "2021-04-18" 1 22
"Blocking-Weekday-28-STAT-MDW21-1111100" "2021-03-15" "2021-04-23" 0 27
"Blocking-Weekday-6-SCT-MDW21-1111100" "2021-03-15" "2021-04-23" 0 27
"StAT-Blk-Saturday-21-STAT-MDW21-0000010" "2021-03-20" "2021-04-24" 0 28
"Blocking-Weekday-9-SCT-MDW21-1111100" "2021-03-26" "2021-04-16" 0 20
"Blocking-Saturday-4-SCT-MDW21-0000010" "2021-03-20" "2021-04-24" 0 28
trip_with_shape_dist_traveled_but_no_shape_distances INFO 3004

trip_with_shape_dist_traveled_but_no_shape_distances

A trip has shape_dist_traveled values in stop_times.txt but the shape referenced by the trip's shape_id does not have shape_dist_traveled values on all of its points in shapes.txt.

When stop times define distance values but the shape does not carry matching distances on every point, consumers cannot use those distances to align stops to the shape geometry reliably. This inconsistency may cause incorrect routing or display behaviour.

Note: Only the first stop time carrying a shape_dist_traveled value is referenced in the notice; this is a representative row rather than an exhaustive list.

You can see more about this notice here.

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

tripCsvRowNumber (?) The row number of the faulty record in trips.txt. tripId (?) The trip_id of the faulty trip. shapeId (?) The shape_id referenced by the trip. stopTimeCsvRowNumber (?) The row number of the first stop_times.txt record for this trip that contains a shape_dist_traveled value. Provided as a representative location; other stop times for the same trip may also carry distance values.
2420 "19864829" "450-9-1" 36524
2419 "19864828" "450-9-1" 36503
713 "19862646" "401-24-1" 372
2416 "19864825" "420-2-1" 36428
714 "19862647" "401-23-1" 382
2415 "19864824" "420-2-1" 36401
2418 "19864827" "450-9-1" 36482
1756 "19863979" "433-1-1" 22538
2417 "19864826" "420-2-1" 36455
1753 "19863974" "490-7-1" 22371
710 "19862643" "401-25-1" 322
1752 "19863973" "490-7-1" 22328
2413 "19864820" "414-22-2" 36371
711 "19862644" "401-25-1" 342
1755 "19863976" "493-7-1" 22476
2414 "19864823" "420-2-1" 36374
712 "19862645" "401-24-1" 362
1754 "19863975" "493-7-1" 22414
1749 "19863970" "440-20-1" 22245
709 "19862640" "401-23-1" 312
1751 "19863972" "490-7-1" 22285
1750 "19863971" "440-20-1" 22265
2852 "19484303" "A15-12-1" 66501
2853 "19484304" "A15-12-1" 66503
2850 "19484301" "A15-12-1" 66497
2851 "19484302" "A15-12-1" 66499
708 "19862639" "401-23-1" 302
2411 "19864818" "414-22-2" 36365
2410 "19864817" "414-21-1" 36362
2849 "19484300" "A15-12-1" 66495
2412 "19864819" "414-22-2" 36368
704 "19862635" "401-25-1" 242
1746 "19863967" "433-1-1" 22172
705 "19862636" "401-25-1" 262
1745 "19863966" "433-1-1" 22139
706 "19862637" "401-24-1" 282
1748 "19863969" "440-20-1" 22225
2409 "19864816" "414-21-1" 36359
707 "19862638" "401-24-1" 292
1747 "19863968" "440-20-1" 22205
2408 "19864815" "414-21-1" 36356
1742 "19863963" "433-1-1" 22040
2856 "19484307" "A15-20-1" 66509
702 "19862633" "401-25-1" 202
1744 "19863965" "433-1-1" 22106
2407 "19864812" "414-21-1" 36353
2854 "19484305" "A15-12-1" 66505
703 "19862634" "401-25-1" 222
1743 "19863964" "433-1-1" 22073
2406 "19864811" "413-51-1" 36343
unknown_file INFO 1

unknown_file

A file is unknown.

You can see more about this notice here.

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