zest — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-03-27T14:46:14Z,
for the dataset file:///shared/zest_76d071dc.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. routes.txt
  5. shapes.txt
  6. stop_times.txt
  7. stops.txt
  8. trips.txt

Counts


  • Agencies: 1
  • Blocks: 66
  • Routes: 35
  • Shapes: 136
  • Stops: 660
  • Trips: 1895

Specification Compliance report

1577 notices reported (0 errors, 1577 warnings, 0 infos)

Notice Code Severity Total
leading_or_trailing_whitespaces WARNING 116

leading_or_trailing_whitespaces

The value in CSV file has leading or trailing whitespaces.

This notice is emitted for values protected with double quotes since whitespaces for non-protected values are trimmed automatically by CSV parser.

The validator strips whitespaces from protected values. We do not see any use case when such a whitespace may be needed. On the other hand, some real-world feeds use trailing whitespaces for some values and omit them for the others. This is causing the largest problem when a primary key and a foreign key differ just by a whitespace: it is clear that they are intended to be the same, that is why we always strip whitespaces.

You can see more about this notice here.

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

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"stop_times.txt" 17156 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17157 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17158 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17159 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17160 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17161 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17162 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17163 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17164 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17165 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17166 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17167 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17168 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17169 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17170 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17171 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17172 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17173 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17174 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17175 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17176 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17177 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17178 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17179 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17180 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17181 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17182 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17183 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17184 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17185 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17186 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17187 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17188 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17189 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17190 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17191 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17192 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17193 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17194 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17195 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17196 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17197 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17198 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17199 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17200 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17201 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17202 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17203 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17204 "stop_headsign" "MALBOUSQUET "
"stop_times.txt" 17205 "stop_headsign" "MALBOUSQUET "
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 1301

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 1301 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.
"stops.txt" "stop_name" "RD2564/RD63" 38
"stops.txt" "stop_name" "2ème escalier" 125
"stops.txt" "stop_name" "RD2564/RD63" 203
"stops.txt" "stop_name" "1er escalier" 435
"stops.txt" "stop_name" "RD2564/RD63" 660
"stops.txt" "stop_name" "RD2564/RD63" 661
"trips.txt" "trip_headsign" "GARE ROUTIERE" 188
"trips.txt" "trip_headsign" "GARE ROUTIERE" 189
"trips.txt" "trip_headsign" "GARE ROUTIERE" 190
"trips.txt" "trip_headsign" "GARE ROUTIERE" 191
"trips.txt" "trip_headsign" "GARE ROUTIERE" 192
"trips.txt" "trip_headsign" "GARE ROUTIERE" 193
"trips.txt" "trip_headsign" "GARE ROUTIERE" 194
"trips.txt" "trip_headsign" "GARE ROUTIERE" 195
"trips.txt" "trip_headsign" "GARE ROUTIERE" 196
"trips.txt" "trip_headsign" "GARE ROUTIERE" 197
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 198
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 199
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 200
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 201
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 202
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 203
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 204
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 205
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 206
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 207
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 208
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 209
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 210
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 211
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 212
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 213
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 214
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 215
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 216
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 217
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 218
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 219
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 220
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 221
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 222
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 223
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 224
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 225
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 226
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 227
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 228
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 229
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 230
"trips.txt" "trip_headsign" "FRONTIERE ST LUDOVIC" 231
non_ascii_or_non_printable_char WARNING 62

non_ascii_or_non_printable_char

Non ascii or non printable char in ID field.

A value of a field with type ID contains non ASCII or non printable characters. This is not recommended.

You can see more about this notice here.

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

filename (?) Name of the faulty file. csvRowNumber (?) Row number of the faulty record. columnName (?) Name of the column where the error occurred. fieldValue (?) Faulty value.
"stop_times.txt" 43436 "stop_id" "GORGÎTE1"
"stop_times.txt" 43466 "stop_id" "GORGÎTE1"
"stop_times.txt" 43496 "stop_id" "GORGÎTE1"
"stop_times.txt" 43526 "stop_id" "GORGÎTE1"
"stop_times.txt" 43556 "stop_id" "GORGÎTE1"
"stop_times.txt" 43586 "stop_id" "GORGÎTE1"
"stop_times.txt" 43616 "stop_id" "GORGÎTE1"
"stop_times.txt" 43646 "stop_id" "GORGÎTE1"
"stop_times.txt" 43676 "stop_id" "GORGÎTE1"
"stop_times.txt" 43706 "stop_id" "GORGÎTE1"
"stop_times.txt" 43736 "stop_id" "GORGÎTE1"
"stop_times.txt" 43766 "stop_id" "GORGÎTE1"
"stop_times.txt" 43796 "stop_id" "GORGÎTE1"
"stop_times.txt" 43826 "stop_id" "GORGÎTE1"
"stop_times.txt" 43856 "stop_id" "GORGÎTE1"
"stop_times.txt" 43886 "stop_id" "GORGÎTE1"
"stop_times.txt" 43916 "stop_id" "GORGÎTE1"
"stop_times.txt" 43946 "stop_id" "GORGÎTE1"
"stop_times.txt" 43976 "stop_id" "GORGÎTE1"
"stop_times.txt" 44006 "stop_id" "GORGÎTE1"
"stop_times.txt" 44036 "stop_id" "GORGÎTE1"
"stop_times.txt" 44066 "stop_id" "GORGÎTE1"
"stop_times.txt" 44096 "stop_id" "GORGÎTE1"
"stop_times.txt" 44126 "stop_id" "GORGÎTE1"
"stop_times.txt" 44156 "stop_id" "GORGÎTE1"
"stop_times.txt" 44186 "stop_id" "GORGÎTE1"
"stop_times.txt" 44216 "stop_id" "GORGÎTE1"
"stop_times.txt" 44246 "stop_id" "GORGÎTE1"
"stop_times.txt" 44842 "stop_id" "GORGÎTE2"
"stop_times.txt" 44873 "stop_id" "GORGÎTE2"
"stop_times.txt" 45482 "stop_id" "GORGÎTE2"
"stop_times.txt" 45512 "stop_id" "GORGÎTE2"
"stop_times.txt" 45542 "stop_id" "GORGÎTE2"
"stop_times.txt" 45572 "stop_id" "GORGÎTE2"
"stop_times.txt" 45602 "stop_id" "GORGÎTE2"
"stop_times.txt" 45632 "stop_id" "GORGÎTE2"
"stop_times.txt" 45662 "stop_id" "GORGÎTE2"
"stop_times.txt" 45692 "stop_id" "GORGÎTE2"
"stop_times.txt" 45722 "stop_id" "GORGÎTE2"
"stop_times.txt" 45752 "stop_id" "GORGÎTE2"
"stop_times.txt" 45782 "stop_id" "GORGÎTE2"
"stop_times.txt" 45812 "stop_id" "GORGÎTE2"
"stop_times.txt" 45842 "stop_id" "GORGÎTE2"
"stop_times.txt" 45872 "stop_id" "GORGÎTE2"
"stop_times.txt" 45902 "stop_id" "GORGÎTE2"
"stop_times.txt" 45932 "stop_id" "GORGÎTE2"
"stop_times.txt" 45962 "stop_id" "GORGÎTE2"
"stop_times.txt" 45992 "stop_id" "GORGÎTE2"
"stop_times.txt" 46022 "stop_id" "GORGÎTE2"
"stop_times.txt" 46052 "stop_id" "GORGÎTE2"
route_color_contrast WARNING 34

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.
"1" 2 "#FF0000" "#FF0000"
"10" 3 "#666699" "#666699"
"12" 4 "#EE82EE" "#EE82EE"
"12S" 5 "#EE82EE" "#EE82EE"
"13" 6 "#006400" "#006400"
"15" 7 "#87CEEB" "#87CEEB"
"18" 8 "#00FFFF" "#00FFFF"
"2" 9 "#FF99CC" "#FF99CC"
"21" 10 "#FFCC99" "#FFCC99"
"22" 11 "#CCFFCC" "#CCFFCC"
"24" 12 "#A52A2A" "#A52A2A"
"3" 13 "#FFD700" "#FFD700"
"4" 14 "#A52A2A" "#A52A2A"
"5" 15 "#006400" "#006400"
"6" 16 "#CCFFCC" "#CCFFCC"
"7" 17 "#D21C73" "#D21C73"
"8" 18 "#008000" "#008000"
"N1" 19 "#000000" "#000000"
"N2" 20 "#000000" "#000000"
"11A" 21 "#000000" "#000000"
"11B" 22 "#000000" "#000000"
"N4" 23 "#000000" "#000000"
"25" 24 "#8B0000" "#8B0000"
"13S" 26 "#000000" "#000000"
"1S" 27 "#000000" "#000000"
"24S" 28 "#000000" "#000000"
"2S" 29 "#000000" "#000000"
"7S" 30 "#000000" "#000000"
"B1" 31 "#000000" "#000000"
"B3" 32 "#000000" "#000000"
"M1" 33 "#000000" "#000000"
"M2" 34 "#000000" "#000000"
"NE" 35 "#000000" "#000000"
"R6" 36 "#000000" "#000000"
route_long_name_contains_short_name WARNING 35

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`.
"1" 2 "1" "1"
"10" 3 "10" "10"
"12" 4 "12" "12"
"12S" 5 "12S" "12S"
"13" 6 "13" "13"
"15" 7 "15" "15"
"18" 8 "18" "18"
"2" 9 "2" "2"
"21" 10 "21" "21"
"22" 11 "22" "22"
"24" 12 "24" "24"
"3" 13 "3" "3"
"4" 14 "4" "4"
"5" 15 "5" "5"
"6" 16 "6" "6"
"7" 17 "7" "7"
"8" 18 "8" "8"
"N1" 19 "N1" "N1"
"N2" 20 "N2" "N2"
"11A" 21 "11A" "11A"
"11B" 22 "11B" "11B"
"N4" 23 "N4" "N4"
"25" 24 "25" "25"
"N3" 25 "N3" "N3"
"13S" 26 "13S" "13S"
"1S" 27 "1S" "1S"
"24S" 28 "24S" "24S"
"2S" 29 "2S" "2S"
"7S" 30 "7S" "7S"
"B1" 31 "B1" "B1"
"B3" 32 "B3" "B3"
"M1" 33 "M1" "M1"
"M2" 34 "M2" "M2"
"NE" 35 "NE" "NE"
"R6" 36 "R6" "R6"
stop_without_stop_time WARNING 28

stop_without_stop_time

A stop in stops.txt is not referenced by any stop_times.stop_id.

Such stops are not used by any trip and normally do not provide user value. This notice may indicate a typo in stop_times.txt.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
2 "DEP" "Depot Zest Bus"
194 "BEA1SER2" "16 route des Serres"
202 "SOSPARK" "Parking Sospel Gare"
221 "MENPÂQU2" "Pâquerettes"
292 "BEARSER1" "Route des Serres"
297 "TENCAST1" "Castérino"
318 "PARK" "Parking Pont Saint Dévote"
325 "TENCAST2" "Castérino"
336 "BEARSER2" "Route des Serres"
441 "SOSSGSN1" "Sospel Gare SNCF"
495 "BEA1SER1" "16 route des Serres"
525 "BEASERR1" "Les Serres"
588 "FONPARK" "Parking Fontan"
607 "SDTVIL3" "St Dalmas de Tende"
609 "TENLMES1" "Lac des Mesches"
613 "TENLMES2" "Lac des Mesches"
614 "TENPTGA1" "Pont des Gasis"
615 "TENPTGA2" "Pont des Gasis"
617 "MENSTM1" "Traverse Saint Michel bis"
627 "BREOLIV2" "Olivaie"
628 "FONRTB1" "Route de Berghe"
629 "FONRTB2" "Route de Berghe"
632 "PARKTEN1" "Parking Gare Sncf TENDE"
635 "BREILENI" "Station service ENI"
636 "DEPFON" "Depot Fontan"
637 "DEPMON" "Depot Monaco - Parking Saint Devotte"
647 "PBEASS" "Plein pour la station service"
648 "PTENST1" "Plein Station Service"