GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-19T23:15:04Z,
for the dataset file:///shared/poznan_552b6c44.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
PKS ONLine
Publisher URL:
https://pksonline.pl
Feed Email:
dzialit@pks.poznan.pl
Feed Language:
Polish
Feed Start Date:
2026-06-01
Feed End Date:
2026-08-31

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_dates.txt
  4. feed_info.txt
  5. routes.txt
  6. shapes.txt
  7. stop_times.txt
  8. stops.txt
  9. timetable_pages.txt
  10. timetables.txt
  11. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 139
  • Shapes: 262
  • Stops: 1202
  • Trips: 626

Specification Compliance report

7980 notices reported (0 errors, 7975 warnings, 5 infos)

Notice Code Severity Total
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 1

equal_shape_distance_diff_coordinates_distance_below_threshold

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 0 but less than 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 small difference of coordinates (greater than 0 but less than 1.11 m distance) result in a warning.

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.
"n583" 109955 25788.789732171594 200 109954 25788.789732171594 199 0.2947369089783529
equal_shape_distance_same_coordinates WARNING 3

equal_shape_distance_same_coordinates

Two consecutive points have equal shape_dist_traveled and the same lat/lon coordinates in shapes.txt.

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 the same coordinates indicate a duplicative shape point.

You can see more about this notice here.

shapeId (?) The id of the faulty shape. csvRowNumber (?) The row number from `shapes.txt`. shapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the faulty record. shapePtSequence (?) The faulty record's `shapes.shape_pt_sequence`. prevCsvRowNumber (?) The row number from `shapes.txt` of the previous shape point. prevShapeDistTraveled (?) Actual distance traveled along the shape from the first shape point to the previous shape point. prevShapePtSequence (?) The previous record's `shapes.shape_pt_sequence`.
"uafy" 148240 9720.331308332674 193 148239 9720.331308332674 192
"7avc" 51627 2739.5658507423104 23 51626 2739.5658507423104 22
"ntlp" 113153 13968.971734579769 57 113152 13968.971734579769 56
leading_or_trailing_whitespaces WARNING 34

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" 1171 "stop_name" "Kościan, ul. Piłsudskiego - Bazar "
"stops.txt" 1172 "stop_name" "Kościan, ul. Piłsudskiego - Bazar "
"stops.txt" 1180 "stop_name" "Kościan, ul. Mickiewicza - Szkoła "
"stops.txt" 1181 "stop_name" "Kościan, Al. Koszewskiego "
"stops.txt" 1186 "stop_name" "Kościan, ul. Broniewskiego - Szkoła "
"trips.txt" 401 "trip_headsign" "Duszniki przez: Sierosław, Niepruszewo, Brzoza "
"trips.txt" 498 "trip_headsign" "Pniewy przez: Swadzim, Tarnowo Podgórne, Bytyń "
"trips.txt" 575 "trip_headsign" "Dolsk przez: Mełpin, Dolsk, Ostrowieczno, Mszczyczyn, Ostrowieczno "
"trips.txt" 584 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 585 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 586 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 587 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 588 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 589 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 590 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 591 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 592 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 593 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 594 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 595 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 596 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 597 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 598 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 599 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 600 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 601 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 602 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 603 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 604 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 605 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 606 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 607 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 608 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
"trips.txt" 609 "trip_headsign" "Kościan, ul. Wyzwolenia - Szkoła przez: Kościan, ul. Piłsudskiego - Bazar "
missing_timepoint_value WARNING 7257

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 7257 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 "2309" 0
3 "2309" 1
4 "2309" 2
5 "2309" 3
6 "2309" 4
7 "2309" 5
8 "2309" 6
9 "2309" 7
10 "2309" 8
11 "2309" 9
12 "2309" 10
13 "2309" 11
14 "2309" 12
15 "2309" 13
16 "2309" 14
17 "2309" 15
18 "2309" 16
19 "2309" 17
20 "2309" 18
21 "2309" 19
22 "2309" 20
65 "2321" 0
66 "2321" 1
67 "2321" 2
68 "2321" 3
69 "2321" 4
70 "2321" 5
71 "2321" 6
72 "2321" 7
73 "2321" 8
74 "2321" 9
75 "2321" 10
76 "2321" 11
77 "2321" 12
78 "2321" 13
79 "2321" 14
80 "2321" 15
81 "2321" 16
82 "2321" 17
83 "2321" 18
84 "2321" 19
85 "2321" 20
128 "2343" 0
129 "2343" 1
130 "2343" 2
131 "2343" 3
132 "2343" 4
133 "2343" 5
134 "2343" 6
135 "2343" 7
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.
"agency.txt" "agency_name" "PKS POZNAŃ S.A." 2
non_ascii_or_non_printable_char WARNING 470

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 470 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.
"calendar.txt" 47 "service_id" "E Ł"
"calendar.txt" 60 "service_id" "Z Ń u"
"calendar.txt" 61 "service_id" "Z Ń *"
"calendar.txt" 62 "service_id" "Z Ł * s"
"calendar.txt" 72 "service_id" "Z Ł *"
"calendar_dates.txt" 3958 "service_id" "E Ł"
"calendar_dates.txt" 3959 "service_id" "E Ł"
"calendar_dates.txt" 3960 "service_id" "E Ł"
"calendar_dates.txt" 3961 "service_id" "E Ł"
"calendar_dates.txt" 3962 "service_id" "E Ł"
"calendar_dates.txt" 3963 "service_id" "E Ł"
"calendar_dates.txt" 3964 "service_id" "E Ł"
"calendar_dates.txt" 3965 "service_id" "E Ł"
"calendar_dates.txt" 3966 "service_id" "E Ł"
"calendar_dates.txt" 3967 "service_id" "E Ł"
"calendar_dates.txt" 3968 "service_id" "E Ł"
"calendar_dates.txt" 3969 "service_id" "E Ł"
"calendar_dates.txt" 3970 "service_id" "E Ł"
"calendar_dates.txt" 3971 "service_id" "E Ł"
"calendar_dates.txt" 3972 "service_id" "E Ł"
"calendar_dates.txt" 3973 "service_id" "E Ł"
"calendar_dates.txt" 3974 "service_id" "E Ł"
"calendar_dates.txt" 3975 "service_id" "E Ł"
"calendar_dates.txt" 3976 "service_id" "E Ł"
"calendar_dates.txt" 3977 "service_id" "E Ł"
"calendar_dates.txt" 3978 "service_id" "E Ł"
"calendar_dates.txt" 3979 "service_id" "E Ł"
"calendar_dates.txt" 3980 "service_id" "E Ł"
"calendar_dates.txt" 3981 "service_id" "E Ł"
"calendar_dates.txt" 3982 "service_id" "E Ł"
"calendar_dates.txt" 3983 "service_id" "E Ł"
"calendar_dates.txt" 3984 "service_id" "E Ł"
"calendar_dates.txt" 3985 "service_id" "E Ł"
"calendar_dates.txt" 3986 "service_id" "E Ł"
"calendar_dates.txt" 3987 "service_id" "E Ł"
"calendar_dates.txt" 3988 "service_id" "E Ł"
"calendar_dates.txt" 3989 "service_id" "E Ł"
"calendar_dates.txt" 3990 "service_id" "E Ł"
"calendar_dates.txt" 3991 "service_id" "E Ł"
"calendar_dates.txt" 3992 "service_id" "E Ł"
"calendar_dates.txt" 3993 "service_id" "E Ł"
"calendar_dates.txt" 3994 "service_id" "E Ł"
"calendar_dates.txt" 3995 "service_id" "E Ł"
"calendar_dates.txt" 3996 "service_id" "E Ł"
"calendar_dates.txt" 3997 "service_id" "E Ł"
"calendar_dates.txt" 3998 "service_id" "E Ł"
"calendar_dates.txt" 3999 "service_id" "E Ł"
"calendar_dates.txt" 4000 "service_id" "E Ł"
"calendar_dates.txt" 4001 "service_id" "E Ł"
"calendar_dates.txt" 4002 "service_id" "E Ł"
route_color_contrast WARNING 1

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.
"01" 138 "#83F706" "#FFFFFF"
stop_too_far_from_shape_using_user_distance WARNING 1

stop_too_far_from_shape_using_user_distance

Stop time too far from shape.

A stop time entry that is a large distance away from the location of the shape in shapes.txt as defined by shape_dist_traveled values.

You can see more about this notice here.

tripCsvRowNumber (?) The row number of the faulty record from `trips.txt`. shapeId (?) The id of the shape that is referred to. tripId (?) The id of the trip that is referred to. stopTimeCsvRowNumber (?) The row number of the faulty record from `stop_times.txt`. stopId (?) The id of the stop that is referred to. stopName (?) The name of the stop that is referred to. match (?) Latitude and longitude pair of the location. geoDistanceToShape (?) Distance from stop to shape.
462 "ke6t" "8144" 8992 "923" "Jarogniewice, Przedszkole" [52.16505836831309,16.696416667786885] 577.6567401766255
stop_without_stop_time WARNING 185

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.

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

csvRowNumber (?) The row number of the faulty record. stopId (?) The id of the faulty stop. stopName (?) The name of the faulty stop.
4 "3" "Będlewo, Wieś"
8 "7" "Białcz, Skrzyżowanie k/Sierakowa"
46 "50" "Bytyń, Bursztynowa"
58 "59" "Choryń"
59 "60" "Choryń"
65 "66" "Chrzypsko Wielkie"
81 "82" "Dąbrowa, I k/Śremu"
84 "85" "Dąbrowa"
144 "154" "Ignacewo k/Krzywinia"
145 "155" "Ignacewo k/Krzywinia"
168 "175" "Katarzynin"
169 "176" "Katarzynin"
188 "197" "Konstantynowo"
189 "198" "Kopaszewo"
190 "199" "Kopaszewo"
202 "207" "Koszanowo, Wieś"
207 "212" "Krajewice, Skrzyżowanie"
208 "213" "Krajewice, Skrzyżowanie"
209 "214" "Krobia"
210 "215" "Krobia"
236 "242" "Łężce"
237 "243" "Łężeczki, Skrzyżowanie"
241 "248" "Łódź, Wieś k/Stęszewa"
246 "253" "Lubosina, PKP"
252 "258" "Luboń, Rutkiewicz"
253 "259" "Luboń, Rutkiewicz"
255 "261" "Luciny, Skrzyżowanie"
279 "288" "Mechlin"
280 "289" "Mechlin"
281 "290" "Mechlin, Skrzyżowanie"
294 "306" "Mórka"
329 "338" "Nowy Tomyśl, Zbąszyńska"
359 "374" "Piersko, Rolna"
370 "386" "Polesie"
371 "387" "Polesie"
375 "391" "Posadowo, Wieś"
387 "403" "Poznań, Łozowa"
389 "405" "Poznań, Rondo Rataje - Dworzec Autobusowy"
393 "409" "Poznań, Starołęka PKM"
444 "457" "Racot"
445 "458" "Racot"
457 "470" "Rogaczewo Małe"
458 "471" "Rogaczewo Małe"
473 "490" "Ryżyn"
493 "477" "Rostarzewo, II - ul. Wolsztyńska NŻ"
518 "533" "Słonin, Świetlica Wiejska"
540 "556" "Srocko Małe"
541 "557" "Srocko Małe"
549 "563" "Stara Krobia II"
550 "564" "Stara Krobia II"
trip_distance_exceeds_shape_distance_below_threshold WARNING 22

trip_distance_exceeds_shape_distance_below_threshold

The distance between the last shape point and last stop point is greater than 0 but less than the 11.1m threshold.

You can see more about this notice here.

tripId (?) The faulty record's trip id. shapeId (?) The faulty record's shape id. maxTripDistanceTraveled (?) The faulty record's trip max distance traveled. maxShapeDistanceTraveled (?) The faulty record's shape max distance traveled. geoDistanceToShape (?) The distance in meters between the shape and the stop.
"699" "guic" 27496.31897042387 27496.31897036391 6.142386687465567
"742" "guic" 27496.31897042387 27496.31897036391 6.142386687465567
"1077" "zwrl" 45687.86969430204 45673.59483377554 6.188489915764827
"4401" "wdk2" 45696.421052779326 45682.143520439706 6.188489915764827
"4402" "zwrl" 45687.86969430204 45673.59483377554 6.188489915764827
"8144" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8140" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8141" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8142" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8143" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8145" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8146" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8147" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8148" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8149" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8150" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"8156" "ke6t" 3289.2352583091943 2709.78295394034 7.630743395261808
"2921" "ap71" 52311.317069464145 52294.97275837842 0.6206085127168413
"2922" "0rzu" 50983.8654917176 50983.83511501658 4.008169167655594
"1961" "1loq" 82328.83382371113 82303.11074605379 6.008274449592893
"1963" "1loq" 82328.83382371113 82303.11074605379 6.008274449592893
"884" "u2sq" 45075.926191236686 45075.78051827031 1.560376833569014
unknown_column INFO 3

unknown_column

A column name is unknown.

You can see more about this notice here.

filename (?) The name of the faulty file. fieldName (?) The name of the unknown column. index (?) The index of the faulty column.
"agency.txt" "agency_branding_url" 7
"feed_info.txt" "feed_id" 2
"routes.txt" "route_branding_url" 8
unknown_file INFO 2

unknown_file

A file is unknown.

You can see more about this notice here.

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