tango — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-19T15:01:23Z,
for the dataset file:///shared/tango_1b640216.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: 0
  • Blocks: 27890
  • Routes: 83
  • Shapes: 421
  • Stops: 1136
  • Trips: 41436

Specification Compliance report

26694 notices reported (0 errors, 24666 warnings, 2028 infos)

Notice Code Severity Total
expired_calendar WARNING 60

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.

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

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
42 "STRAIT0925-M_PERH25-Samedi-47"
45 "STRAIT0925-M_PERH25-Samedi-63"
51 "STRAIT0925-M_PERH25-L-Ma-J-V-50"
52 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1101100"
53 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1001100"
54 "STRAIT0925-M_PERH25-L-Ma-J-V-50-0100000"
55 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1001000"
56 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1101000"
58 "STRAIT0925-M_PERH25-L-Ma-J-V-50-0101100"
59 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1000000"
60 "STRAIT0925-M_PERH25-L-Ma-J-V-50-1100000"
61 "STRAIT0925-M_PERH25-L-Ma-J-V-50-0001000"
62 "STRAIT0925-M_PERH25-L-Ma-J-V-50-0001100"
63 "STRAIT0925-M_PERH25-L-Ma-J-V-52"
64 "STRAIT0925-M_PERH25-L-Ma-J-V-52-1101100"
65 "STRAIT0925-M_PERH25-L-Ma-J-V-52-1001100"
69 "STRAIT0925-M_PERH25-L-Ma-J-V-52-0000100"
70 "STRAIT0925-M_PERH25-L-Ma-J-V-52-0101100"
74 "STRAIT0925-M_PERH25-L-Ma-J-V-52-0001100"
97 "STRAIT0925-M_PERH25-L-Ma-J-V-57"
98 "STRAIT0925-M_PERH25-L-Ma-J-V-57-1101100"
100 "STRAIT0925-M_PERH25-L-Ma-J-V-57-0100000"
102 "STRAIT0925-M_PERH25-L-Ma-J-V-57-1101000"
104 "STRAIT0925-M_PERH25-L-Ma-J-V-57-0101100"
106 "STRAIT0925-M_PERH25-L-Ma-J-V-57-1100000"
118 "STRAIT0925-M_PERH25-L-Ma-J-V-59"
119 "STRAIT0925-M_PERH25-L-Ma-J-V-59-1101100"
120 "STRAIT0925-M_PERH25-L-Ma-J-V-59-1001100"
122 "STRAIT0925-M_PERH25-L-Ma-J-V-59-1001000"
123 "STRAIT0925-M_PERH25-L-Ma-J-V-59-1101000"
125 "STRAIT0925-M_PERH25-L-Ma-J-V-59-0101100"
128 "STRAIT0925-M_PERH25-L-Ma-J-V-59-0001000"
129 "STRAIT0925-M_PERH25-L-Ma-J-V-59-0001100"
130 "STRAIT0925-M_PERH25-L-Ma-J-V-60"
131 "STRAIT0925-M_PERH25-L-Ma-J-V-60-1101100"
132 "STRAIT0925-M_PERH25-L-Ma-J-V-60-1001100"
136 "STRAIT0925-M_PERH25-L-Ma-J-V-60-0000100"
137 "STRAIT0925-M_PERH25-L-Ma-J-V-60-0101100"
141 "STRAIT0925-M_PERH25-L-Ma-J-V-61"
142 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1101100"
143 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1001100"
144 "STRAIT0925-M_PERH25-L-Ma-J-V-61-0100000"
145 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1001000"
146 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1101000"
148 "STRAIT0925-M_PERH25-L-Ma-J-V-61-0101100"
149 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1000000"
150 "STRAIT0925-M_PERH25-L-Ma-J-V-61-1100000"
181 "STRAIT0925-M_PERH25-L-Ma-J-V-65"
182 "STRAIT0925-M_PERH25-L-Ma-J-V-65-1101100"
183 "STRAIT0925-M_PERH25-L-Ma-J-V-65-1001100"
leading_or_trailing_whitespaces WARNING 2

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.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"routes.txt" 13 "route_long_name" " POULX-ADA LOVELACE-SULLY"
"routes.txt" 70 "route_long_name" " F.DESMONS - MONTIGNARGUES-PARIGNARGUES-GAJAN"
missing_recommended_field WARNING 84

missing_recommended_field

A recommended field is missing.

The given field has no value in some input row, even though values are recommended.

You can see more about this notice here.

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

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"agency.txt" 2 "agency_id"
"routes.txt" 2 "agency_id"
"routes.txt" 3 "agency_id"
"routes.txt" 4 "agency_id"
"routes.txt" 5 "agency_id"
"routes.txt" 6 "agency_id"
"routes.txt" 7 "agency_id"
"routes.txt" 8 "agency_id"
"routes.txt" 9 "agency_id"
"routes.txt" 10 "agency_id"
"routes.txt" 11 "agency_id"
"routes.txt" 12 "agency_id"
"routes.txt" 13 "agency_id"
"routes.txt" 14 "agency_id"
"routes.txt" 15 "agency_id"
"routes.txt" 16 "agency_id"
"routes.txt" 17 "agency_id"
"routes.txt" 18 "agency_id"
"routes.txt" 19 "agency_id"
"routes.txt" 20 "agency_id"
"routes.txt" 21 "agency_id"
"routes.txt" 22 "agency_id"
"routes.txt" 23 "agency_id"
"routes.txt" 24 "agency_id"
"routes.txt" 25 "agency_id"
"routes.txt" 26 "agency_id"
"routes.txt" 27 "agency_id"
"routes.txt" 28 "agency_id"
"routes.txt" 29 "agency_id"
"routes.txt" 30 "agency_id"
"routes.txt" 31 "agency_id"
"routes.txt" 32 "agency_id"
"routes.txt" 33 "agency_id"
"routes.txt" 34 "agency_id"
"routes.txt" 35 "agency_id"
"routes.txt" 36 "agency_id"
"routes.txt" 37 "agency_id"
"routes.txt" 38 "agency_id"
"routes.txt" 39 "agency_id"
"routes.txt" 40 "agency_id"
"routes.txt" 41 "agency_id"
"routes.txt" 42 "agency_id"
"routes.txt" 43 "agency_id"
"routes.txt" 44 "agency_id"
"routes.txt" 45 "agency_id"
"routes.txt" 46 "agency_id"
"routes.txt" 47 "agency_id"
"routes.txt" 48 "agency_id"
"routes.txt" 49 "agency_id"
"routes.txt" 50 "agency_id"
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 24517

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 24517 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.
"routes.txt" "route_long_name" "CALVAS - HALLE DES SPORTS" 2
"routes.txt" "route_long_name" "VALMY - VILLE ACTIVE" 3
"routes.txt" "route_long_name" "GALILEE - PONT DE JUSTICE" 4
"routes.txt" "route_long_name" "ROUTE D'ALES - BOUILLARGUES/ROUTE D'ARLES" 5
"routes.txt" "route_long_name" "MAS D'ESCATTES - GARE FEUCHERES" 6
"routes.txt" "route_long_name" "BERNIS - MILHAUD - GARE TRIAIRE" 7
"routes.txt" "route_long_name" "POULX - NÎMES" 8
"routes.txt" "route_long_name" "MAS DES ROSIERS - GARE FEUCHERES" 9
"routes.txt" "route_long_name" "VACQUEROLLES GOLF/ CASTANET - PONT DE JUSTICE" 10
"routes.txt" "route_long_name" "LAENNEC - PONT DE JUSTICE" 11
"routes.txt" "route_long_name" "SERRE CAVALIER - VILLE ACTIVE" 12
"routes.txt" "route_long_name" "POULX-ADA LOVELACE-SULLY" 13
"routes.txt" "route_long_name" "NAVETTE MARGUERITTES" 14
"routes.txt" "route_long_name" "LEDENON - NIMES" 15
"routes.txt" "route_long_name" "SERNHAC - NIMES" 16
"routes.txt" "route_long_name" "REDESSAN - NIMES" 17
"routes.txt" "route_long_name" "MANDUEL - NIMES" 18
"routes.txt" "route_long_name" "NAVETTE GARES" 19
"routes.txt" "route_long_name" "GARONS - CAISSARGUES - NIMES" 20
"routes.txt" "route_long_name" "SAINT GILLES - CAISSARGUES - NIMES" 21
"routes.txt" "route_long_name" "GENERAC - NIMES" 22
"routes.txt" "route_long_name" "ST DIONISY - LANGLADE" 23
"routes.txt" "route_long_name" "CAVEIRAC - MARUEJOLS/CLARENSAC" 24
"routes.txt" "route_long_name" "SAINT CHAPTES - NIMES" 25
"routes.txt" "route_long_name" "SAINTE-ANASTASIE- SAINT GENIES DE MALGOIRES" 26
"routes.txt" "route_long_name" "HAUTS DE NIMES - JAURES" 27
"routes.txt" "route_long_name" "ANTIQUAILLES - GAMBETTA COUPOLE" 28
"routes.txt" "route_long_name" "MASSILLAN - DAGUET" 29
"routes.txt" "route_long_name" "MAS MICHEL - DAGUET" 30
"routes.txt" "route_long_name" "GOELANDS - LEA BLAIN" 31
"routes.txt" "route_long_name" "BAS DE THOLOZAN - BOUQUERIE" 32
"routes.txt" "route_long_name" "CHAMBRE D'AGRICULTURE - GARE TRIAIRE" 33
"routes.txt" "route_long_name" "MONTAURY - JAURES" 34
"routes.txt" "route_long_name" "CAMPLANIER - JAURES" 35
"routes.txt" "route_long_name" "EAU BOUILLIE" 36
"routes.txt" "route_long_name" "AIR PUR - 3 PONTS" 37
"routes.txt" "route_long_name" "MAS DE ROULAN - BOUQUERIE" 38
"routes.txt" "route_long_name" "CONDAMINE - GARE TRIAIRE" 39
"routes.txt" "route_long_name" "NAVETTE GALILEE - CAPITELLES" 40
"routes.txt" "route_long_name" "JAURES - SERRE CAVALIER" 41
"routes.txt" "route_long_name" "COLLEGE JULES VERNE - MAS ROMAN" 42
"routes.txt" "route_long_name" "COLLEGE JEAN ROSTAND - PISSEVIN" 43
"routes.txt" "route_long_name" "COLLEGE JEAN ROSTAND-VACQUEROLLES-GOLF-P.VEDELIN" 44
"routes.txt" "route_long_name" "COLLEGE JULES VERNE - ROMARINS" 45
"routes.txt" "route_long_name" "LYCEE CAMUS - MAS ROMAN" 46
"routes.txt" "route_long_name" "COLLEGE JEAN ROSTAND - CAMPLANIER" 47
"routes.txt" "route_long_name" "MAZET DES MOURGUES - NIMES GARE ROUTIERE" 48
"routes.txt" "route_long_name" "COLLEGE LOU CASTELLAS - POULX" 49
"routes.txt" "route_long_name" "COLLEGE LOU CASTELLAS - LEDENON" 50
"routes.txt" "route_long_name" "LYCEE AGRICOLE DE RODILHAN - MARGUERITTES" 51
unexpected_enum_value WARNING 2

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" 34 "route_type" 715
"routes.txt" 41 "route_type" 715
big_gap_in_service INFO 4

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.
"ETE2026-E_ETE26-Semaine-07" "2026-07-09" "2026-07-30" 20
"ETE2026-E-ETE26-Samedi-03" "2026-08-01" "2026-08-22" 20
"JANV2026-H_JANV26-Samedi-23" "2026-06-13" "2026-07-04" 20
"JANV2026-H_JANV26-Dimanche-25" "2026-06-07" "2026-07-05" 27
trip_headsign_matches_intermediate_stop INFO 2024

trip_headsign_matches_intermediate_stop

Trip headsign matches the name of an intermediate stop, not the last stop.

The trip_headsign matches the stop_name of a stop that is not the last stop of the trip. This may confuse passengers boarding after that stop, since the headsign suggests the vehicle is heading to a stop it has already passed.

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record in `trips.txt`. tripId (?) The id of the trip with the problematic headsign. tripHeadsign (?) The headsign value that matches an intermediate stop name. stopId1 (?) The id of the intermediate stop whose name matches the headsign. stopSequence (?) The stop_sequence value of the intermediate stop that matches the headsign. stopId2 (?) The id of the actual last stop of the trip.
117 "9703892-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
118 "9703893-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
119 "9703894-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
120 "9703895-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
121 "9703896-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
122 "9703897-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
123 "9703898-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
124 "9703899-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
125 "9703900-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
126 "9703901-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
127 "9703902-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
128 "9703903-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
129 "9703904-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
130 "9703905-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
131 "9703906-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
132 "9703907-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
133 "9703908-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
134 "9703909-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
135 "9703910-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
136 "9703911-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
137 "9703912-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
138 "9703913-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
139 "9703914-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
140 "9703915-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
141 "9703916-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
142 "9703917-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
143 "9703918-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
144 "9703919-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
145 "9703920-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
146 "9703921-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
147 "9703922-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
148 "9703923-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
149 "9703924-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
150 "9703925-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
151 "9703926-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
152 "9703927-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
153 "9703928-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
154 "9703929-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
155 "9703930-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
156 "9703931-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
157 "9703932-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
158 "9703933-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
159 "9703934-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
160 "9703935-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "VALDT"
161 "9703936-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "ROMAA"
162 "9703937-ETE2026-E_ETE26-Semaine-05" "GALILEE" "VA" 12 "ROMAA"
248 "9706781-ETE2026-E_ETE26-Semaine-05" "CAISSARGUES" "NCAIS1" 21 "NCAIS3"
249 "9706782-ETE2026-E_ETE26-Semaine-05" "CAISSARGUES" "NCAIS1" 21 "NCAIS3"
250 "9706783-ETE2026-E_ETE26-Semaine-05" "CAISSARGUES" "NCAIS1" 21 "NCAIS3"
251 "9706784-ETE2026-E_ETE26-Semaine-05" "CAISSARGUES" "NCAIS1" 21 "NCAIS3"