scoltus — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-04-17T17:35:35Z,
for the dataset file:///shared/scoltus_cc461a0a.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
  9. trips_extensions.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 54
  • Shapes: 124
  • Stops: 379
  • Trips: 0

Specification Compliance report

1350 notices reported (21 errors, 1322 warnings, 7 infos)

Notice Code Severity Total
equal_shape_distance_diff_coordinates ERROR 16

equal_shape_distance_diff_coordinates

Two consecutive points have equal shape_dist_traveled and different lat/lon coordinates in shapes.txt and the distance between the two points is greater than the 1.11m.

When sorted by shape.shape_pt_sequence, the values for shape_dist_traveled must increase along a shape. Two consecutive points with equal values for shape_dist_traveled and different coordinates indicate an error.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) The faulty record's `shape_dist_traveled` value. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) The previous shape point's `shape_dist_traveled` value. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`. actualDistanceBetweenShapePoints (?) Actual distance traveled along the shape from the first shape point to the previous shape point.
"R-101R1" 731 0.0 5 730 0.0 4 1104.1231981524245
"TRP-R-200R2" 69 0.0 6 68 0.0 5 1058.7594440246494
"TRP-R-103R3" 17 0.0 2 16 0.0 1 1756.8874622163912
"TRP-R-103R3" 18 0.0 3 17 0.0 2 1725.014236435398
"TRP-R-103R3" 19 0.0 4 18 0.0 3 1982.1186468462088
"TRP-R-103R1" 23 0.0 2 22 0.0 1 1756.8874622163912
"TRP-R-103R1" 24 0.0 3 23 0.0 2 1725.014236435398
"TRP-R-103R1" 25 0.0 4 24 0.0 3 1982.1186468462088
"TRP-A-103A1" 158 0.0 4 157 0.0 3 2015.8193383646367
"TRP-A-103A1" 159 0.0 5 158 0.0 4 1756.8874622163912
"TRP-A-103A1" 160 0.0 6 159 0.0 5 1725.014236435398
"TRP-A-103A2" 13 0.0 4 12 0.0 3 2015.8193383646367
"TRP-A-103A2" 14 0.0 5 13 0.0 4 1756.8874622163912
"TRP-A-103A2" 15 0.0 6 14 0.0 5 1725.014236435398
"A-101A1" 724 0.0 7 723 0.0 6 1463.01867064067
"A-101A1" 725 0.0 8 724 0.0 7 2622.1352799433407
missing_required_field ERROR 4

missing_required_field

A required field is missing.

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

You can see more about this notice here.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"trips.txt" 122 "service_id"
"trips.txt" 123 "service_id"
"trips.txt" 124 "service_id"
"trips.txt" 125 "service_id"
point_near_origin ERROR 1

point_near_origin

A point is too close to origin (0, 0).

You can see more about this notice here.

filename (?) The name of the affected GTFS file. csvRowNumber (?) The row of the faulty row. entityId (?) The id of the faulty entity. latFieldName (?) The name of the field that uses latitude value. latFieldValue (?) The latitude of the faulty row. lonFieldName (?) The name of the field that uses longitude value. lonFieldValue (?) The longitude of the faulty row
"stops.txt" 79 "STA-STP-HOTEL-DE-VILLE" "stop_lat" 0.0 "stop_lon" 0.0
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.
"stops.txt" 363 "stop_code" "TEREGL "
"trips.txt" 94 "trip_headsign" "204R2 "
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"
missing_timepoint_value WARNING 925

missing_timepoint_value

stop_times.timepoint value is missing for a record.

When at least one of stop_times.arrival_time or stop_times.departure_time are provided, stop_times.timepoint should be defined

You can see more about this notice here.

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

csvRowNumber (?) The row number of the faulty record. tripId (?) The faulty record's `stop_times.trip_id`. stopSequence (?) The faulty record's `stop_times.stop_sequence`.
2 "R-N2N1" 1
3 "R-N2N1" 2
4 "R-N2N1" 3
5 "TRP-R-102R1" 1
6 "TRP-R-102R1" 2
7 "TRP-R-102R1" 3
8 "TRP-R-102R1" 4
9 "TRP-R-102R1" 5
10 "TRP-A-103A2" 1
11 "TRP-A-103A2" 2
12 "TRP-A-103A2" 3
13 "TRP-A-103A2" 4
14 "TRP-A-103A2" 5
15 "TRP-A-103A2" 6
16 "TRP-R-103R3" 1
17 "TRP-R-103R3" 2
18 "TRP-R-103R3" 3
19 "TRP-R-103R3" 4
20 "TRP-R-103R3" 5
21 "TRP-R-103R3" 6
22 "TRP-R-103R1" 1
23 "TRP-R-103R1" 2
24 "TRP-R-103R1" 3
25 "TRP-R-103R1" 4
26 "TRP-R-103R1" 5
27 "TRP-R-103R1" 6
28 "TRP-A-104A1" 1
29 "TRP-A-104A1" 2
30 "TRP-A-104A1" 3
31 "TRP-A-105A2" 2
32 "TRP-A-105A2" 3
33 "TRP-A-105A2" 4
34 "TRP-A-105A2" 5
35 "TRP-A-105A2" 6
36 "TRP-A-105A2" 7
37 "TRP-A-105A2" 8
38 "TRP-A-105A2" 9
39 "TRP-A-105A1" 1
40 "TRP-A-105A1" 2
41 "TRP-A-105A1" 3
42 "TRP-A-105A1" 4
43 "TRP-A-105A1" 5
44 "TRP-A-105A1" 6
45 "TRP-A-105A1" 7
46 "TRP-A-105A1" 8
47 "TRP-A-105A1" 9
48 "TRP-R-105R1" 1
49 "TRP-R-105R1" 2
50 "TRP-R-105R1" 3
51 "TRP-R-105R1" 4
mixed_case_recommended_field WARNING 366

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 366 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.
"agency.txt" "agency_name" "SCOL'TUS" 2
"stops.txt" "stop_name" "BERZY LE SEC-GARE R" 2
"stops.txt" "stop_name" "ACY-LE BAS ECOLE ABRI" 3
"stops.txt" "stop_name" "ACY LE BAS SALLE DES FÊTES A" 4
"stops.txt" "stop_name" "ACY LE BAS SALLE DES FÊTES R" 5
"stops.txt" "stop_name" "ACY-LE HAUT EGLISE ABRI" 6
"stops.txt" "stop_name" "BAGNEUX-MAIRIE ABRI" 7
"stops.txt" "stop_name" "BELLEU-AMPERE" 8
"stops.txt" "stop_name" "BELLEU-COLLEGE" 9
"stops.txt" "stop_name" "BELLEU-MAIRIE" 10
"stops.txt" "stop_name" "BERZY LE SEC-GARE" 11
"stops.txt" "stop_name" "BERZY LE SEC - GARE R" 12
"stops.txt" "stop_name" "BERZY LE SEC-MAIRIE ABRI" 13
"stops.txt" "stop_name" "BILLY SUR AISNE - BOIS DE L'EGLISE ABRI" 15
"stops.txt" "stop_name" "BILLY SUR AISNE CROIX LAHORE TUS" 16
"stops.txt" "stop_name" "BILLY SUR AISNE-LA PAIX" 17
"stops.txt" "stop_name" "BRAYE-LA JOCIENNE ABRI" 18
"stops.txt" "stop_name" "BUCY-LES GREVIERES" 19
"stops.txt" "stop_name" "BUCY LE LONG-BROYON ABRI" 22
"stops.txt" "stop_name" "BUCY LE LONG -JULES FERRY ABRI TUS" 23
"stops.txt" "stop_name" "BUCY LE LONG LAFFAUX ABRI" 24
"stops.txt" "stop_name" "BUCY LE LONG MAIRIE ABRI" 25
"stops.txt" "stop_name" "BUCY LE LONG - SUCRERIE" 26
"stops.txt" "stop_name" "CHAUDUN-PLACE BERNARD AUBERT" 29
"stops.txt" "stop_name" "CHAVIGNY-CENTRE ABRI" 30
"stops.txt" "stop_name" "CHIVRES VAL-LAMARTINE" 31
"stops.txt" "stop_name" "CIRY SALSOGNE-LE CHAMP PART" 32
"stops.txt" "stop_name" "CIRY SALSOGNE-DOMAINE DES ETANGS ABRI" 33
"stops.txt" "stop_name" "CIRY SALSOGNE-ECOLE ABRI" 34
"stops.txt" "stop_name" "CIRY SALSOGNE-GARE ABRI" 35
"stops.txt" "stop_name" "CIRY SALSOGNE-LA POSTE" 36
"stops.txt" "stop_name" "CIRY SALSOGNE-ROUTE DE CHASSEMY ABRI" 37
"stops.txt" "stop_name" "CIRY SALSOGNE-RUE DE MONTPELLIER ABRI" 38
"stops.txt" "stop_name" "CLAMECY-ABRI" 39
"stops.txt" "stop_name" "COURMELLES-LA ROCHE A" 40
"stops.txt" "stop_name" "COURMELLES-LA ROCHE R" 41
"stops.txt" "stop_name" "COURMELLES - CONDORCET A" 42
"stops.txt" "stop_name" "COURMELLES - CONDORCET R" 43
"stops.txt" "stop_name" "COURMELLES-CHEMIN DES VENDANGES" 44
"stops.txt" "stop_name" "COURMELLES-CHEMIN DES VENDANGES B" 45
"stops.txt" "stop_name" "COURMELLES-ECOLE" 46
"stops.txt" "stop_name" "COURMELLES-EGLISE ABRI" 47
"stops.txt" "stop_name" "COURMELLES-MAIRIE TUS" 48
"stops.txt" "stop_name" "COURMELLES-SAINT FELIX" 49
"stops.txt" "stop_name" "COURMELLES-VIGNOLLES ABRI" 50
"stops.txt" "stop_name" "CROUY - CLEMENCIN TUS A" 53
"stops.txt" "stop_name" "CROUY - CLEMENCIN TUS R" 54
"stops.txt" "stop_name" "CROUY-CLEMENCINS ABRI" 55
"stops.txt" "stop_name" "CROUY-ECOLE TIVOLI" 56
"stops.txt" "stop_name" "CROUY-EGLISE ABRI" 57
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.
168 "STP-ACY-LE-BAS-SALLE-DES-FETES-A" "ACY-LE BAS SALLE DES FÊTES A"
169 "STP-ACY-LE-BAS-SALLE-DES-FETES-R" "ACY-LE BAS SALLE DES FÊTES R"
174 "STP-BELLEU-AMPERE-R" "BELLEU-AMPERE R"
177 "STP-BELLEU-MAIRIE-R" "BELLEU-MAIRIE R"
182 "STP-BILLY-SUR-AISNE-CROIX-LAHORE-TUS" "BILLY SUR AISNE CROIX LAHORE TUS"
209 "STP-CIRY-SALSOGNE-GARE-ABRI" "CIRY SALSOGNE-GARE ABRI"
221 "STP-COURMELLES-ECOLE-A" "COURMELLES-ECOLE A"
222 "STP-COURMELLES-ECOLE-R" "COURMELLES-ECOLE R"
237 "STP-CROUY-ECOLE-TIVOLI-A" "CROUY-ECOLE TIVOLI A"
281 "STP-MERCI-ET-VAUX-JOLIOT-CURIE" "MERCI ET VAUX-JOLIOT CURIE"
282 "STP-MERCIN-ET-VAUX-CALVAIRE-A" "MERCIN ET VAUX-CALVAIRE A"
283 "STP-MERCIN-ET-VAUX-CALVAIRE-R" "MERCIN ET VAUX-CALVAIRE R"
284 "STP-MERCIN-ET-VAUX-ETANG-DU-VER-DE-VASE-A" "MERCIN ET VAUX-ETANG DU VER DE VASE A"
285 "STP-MERCIN-ET-VAUX-ETANG-DU-VER-DE-VASE-R" "MERCIN ET VAUX-ETANG DU VER DE VASE R"
286 "STP-MERCIN-ET-VAUX-GARE-A" "MERCIN ET VAUX-GARE A"
287 "STP-MERCIN-ET-VAUX-GARE-R" "MERCIN ET VAUX-GARE R"
289 "STP-MERCIN-ET-VAUX-LA-LOUVIERE-A" "MERCIN ET VAUX-LA LOUVIÈRE A"
290 "STP-MERCIN-ET-VAUX-LA-LOUVIERE-R" "MERCIN ET VAUX-LA LOUVIÈRE R"
291 "STP-MERCIN-ET-VAUX-LES-HAUTS-RIEZ" "MERCIN ET VAUX-LES HAUTS RIEZ"
292 "STP-MERCIN-ET-VAUX-MAISON-BLANCHE-A" "MERCIN ET VAUX-MAISON BLANCHE A"
293 "STP-MERCIN-ET-VAUX-MAISON-BLANCHE-R" "MERCIN ET VAUX-MAISON BLANCHE R"
316 "STP-OSLY-COURTIL-PLACE-ECOLE" "OSLY - COURTIL-PLACE ECOLE"
334 "STP-SACONIN-ET-BREUIL-BREUIL-A" "SACONIN ET BREUIL-BREUIL A"
350 "STP-SOISSONS-BARA-A" "SOISSONS-BARA A"
351 "STP-SOISSONS-BARA-R" "SOISSONS-BARA R"
353 "STP-SOISSONS-G-PLACE-NAV" "SOISSONS-G PLACE NAV"
355 "STP-SOISSONS-GRAND-PLACE" "SOISSONS-GRAND PLACE"
358 "STP-SOISSONS-MARQUIGNY" "SOISSONS-MARQUIGNY"
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.
"trips_extensions.txt"
unused_station INFO 6

unused_station

Unused station.

A stop has location_type STATION (1) but does not appear in any stop's parent_station.

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.
79 "STA-STP-HOTEL-DE-VILLE" "Hotel de ville"
45 "STA-STP-COURMELLES-CHEMIN-DES-VENDANGES-B" "COURMELLES-CHEMIN DES VENDANGES B"
152 "STA-STP-TERNY-SORNY-RD1-ABRI" "TERNY SORNY-CHATEAU D'EAU"
130 "STA-STP-SERCHES-MOULIN-R" "SERCHES-MOULIN"
12 "STA-STP-BERZY-LE-SEC-GARE-R" "BERZY LE SEC - GARE R"
142 "STA-STP-SOISSONS-HOTEL-DE-VILLE-1" "SOISSONS-HÔTEL DE VILLE 1"