GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 8.0.1 at 2026-06-20T06:40:01Z,
for the dataset file:///shared/otwock_be46f548.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
unofficial OTWOCK gtfs, generated from T4B by lz
Feed Email:
N/A
Feed Language:
Polish
Feed Start Date:
2026-06-10
Feed End Date:
2026-06-23

Files included


  1. agency.txt
  2. calendar_dates.txt
  3. fare_leg_rules.txt
  4. fare_products.txt
  5. feed_info.txt
  6. routes.txt
  7. shapes.txt
  8. stop_times.txt
  9. stops.txt
  10. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 5
  • Shapes: 23
  • Stops: 90
  • Trips: 1548

Specification Compliance report

1915 notices reported (865 errors, 868 warnings, 182 infos)

Notice Code Severity Total
duplicate_key ERROR 865

duplicate_key

Duplicated entity.

The values of the given key and rows are duplicates.

You can see more about this notice here.

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

filename (?) The name of the faulty file oldCsvRowNumber (?) The row of the first occurrence. newCsvRowNumber (?) The row of the other occurrence. fieldName1 (?) Composite key's first field name. fieldValue1 (?) Composite key's first value.
"routes.txt" 2 3 "route_id" ".M1+M2+M3"
"routes.txt" 4 5 "route_id" "M1"
"routes.txt" 6 7 "route_id" "M2"
"shapes.txt" 659 2467 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,0"
"shapes.txt" 660 2468 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,1"
"shapes.txt" 661 2469 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,2"
"shapes.txt" 662 2470 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,3"
"shapes.txt" 663 2471 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,4"
"shapes.txt" 664 2472 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,5"
"shapes.txt" 665 2473 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,6"
"shapes.txt" 666 2474 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,7"
"shapes.txt" 667 2475 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,8"
"shapes.txt" 668 2476 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,9"
"shapes.txt" 669 2477 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,10"
"shapes.txt" 670 2478 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,11"
"shapes.txt" 671 2479 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,12"
"shapes.txt" 672 2480 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,13"
"shapes.txt" 673 2481 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,14"
"shapes.txt" 674 2482 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,15"
"shapes.txt" 675 2483 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,16"
"shapes.txt" 676 2484 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,17"
"shapes.txt" 677 2485 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,18"
"shapes.txt" 678 2486 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,19"
"shapes.txt" 679 2487 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,20"
"shapes.txt" 680 2488 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,21"
"shapes.txt" 681 2489 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,22"
"shapes.txt" 682 2490 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,23"
"shapes.txt" 683 2491 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,24"
"shapes.txt" 684 2492 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,25"
"shapes.txt" 685 2493 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,26"
"shapes.txt" 686 2494 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,27"
"shapes.txt" 687 2495 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,28"
"shapes.txt" 688 2496 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,29"
"shapes.txt" 689 2497 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,30"
"shapes.txt" 690 2498 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,31"
"shapes.txt" 691 2499 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,32"
"shapes.txt" 692 2500 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,33"
"shapes.txt" 693 2501 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,34"
"shapes.txt" 694 2502 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,35"
"shapes.txt" 695 2503 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,36"
"shapes.txt" 696 2504 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,37"
"shapes.txt" 697 2505 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,38"
"shapes.txt" 698 2506 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,39"
"shapes.txt" 699 2507 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,40"
"shapes.txt" 700 2508 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,41"
"shapes.txt" 701 2509 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,42"
"shapes.txt" 702 2510 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,43"
"shapes.txt" 703 2511 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,44"
"shapes.txt" 704 2512 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,46"
"shapes.txt" 705 2513 "shape_id,shape_pt_sequence" ".M1+M2+M3_5_9G9h3famrqs3VVxR-RTUMw==,47"
duplicate_route_name WARNING 3

duplicate_route_name

Two distinct routes have either the same route_short_name, the same route_long_name, or the same combination of route_short_name and route_long_name.

All routes of the same route_type with the same agency_id should have unique combinations of route_short_name and route_long_name.

Note that there may be valid cases where routes have the same short and long name, e.g., if they serve different areas. However, different directions must be modeled as the same route.

Example of bad data:

route_id route_short_name route_long_name
route1 U1 Southern
route2 U1 Southern

You can see more about this notice here.

csvRowNumber1 (?) The row number of the first occurrence. routeId1 (?) The id of the the first occurrence. csvRowNumber2 (?) The row number of the other occurrence. routeId2 (?) The id of the the other occurrence. routeShortName (?) Common `routes.route_short_name`. routeLongName (?) Common `routes.route_long_name`. routeTypeValue (?) Common `routes.route_type`. agencyId (?) Common `routes.agency_id`.
2 ".M1+M2+M3" 3 ".M1+M2+M3" ".M1+M2+M3" "" 3 "1"
4 "M1" 5 "M1" "M1" "" 3 "1"
6 "M2" 7 "M2" "M2" "" 3 "1"
equal_shape_distance_same_coordinates WARNING 862

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.

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

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`.
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2935 0.0 0 1127 0.0 0
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2936 0.007 1 1128 0.007 1
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2937 0.024 2 1129 0.024 2
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2938 0.041 3 1130 0.041 3
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2939 0.046 4 1131 0.046 4
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2940 0.049 5 1132 0.049 5
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2941 0.067 6 1133 0.067 6
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2942 0.092 7 1134 0.092 7
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2943 0.114 8 1135 0.114 8
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2944 0.124 9 1136 0.124 9
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2945 0.139 10 1137 0.139 10
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2946 0.162 11 1138 0.162 11
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2947 0.201 12 1139 0.201 12
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2948 0.206 13 1140 0.206 13
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2949 0.268 14 1141 0.268 14
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2950 0.365 15 1142 0.365 15
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2951 0.373 16 1143 0.373 16
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2952 0.376 17 1144 0.376 17
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2953 0.384 18 1145 0.384 18
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2954 0.42 19 1146 0.42 19
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2955 0.452 20 1147 0.452 20
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2956 0.505 21 1148 0.505 21
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2957 0.514 22 1149 0.514 22
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2958 0.553 23 1150 0.553 23
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2959 0.554 24 1151 0.554 24
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2960 0.561 25 1152 0.561 25
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2961 0.574 26 1153 0.574 26
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2962 0.6 27 1154 0.6 27
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2963 0.635 28 1155 0.635 28
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2964 0.705 29 1156 0.705 29
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2965 0.771 30 1157 0.771 30
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2966 0.797 31 1158 0.797 31
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2967 0.804 32 1159 0.804 32
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2968 0.904 33 1160 0.904 33
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2969 0.977 34 1161 0.977 34
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2970 1.113 35 1162 1.113 35
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2971 1.176 36 1163 1.176 36
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2972 1.201 37 1164 1.201 37
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2973 1.291 38 1165 1.291 38
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2974 1.345 39 1166 1.345 39
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2975 1.361 40 1167 1.361 40
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2976 1.368 41 1168 1.368 41
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2977 1.378 42 1169 1.378 42
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2978 1.457 43 1170 1.457 43
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2979 1.552 44 1171 1.552 44
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2980 1.57 45 1172 1.57 45
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2981 1.584 46 1173 1.584 46
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2982 1.633 47 1174 1.633 47
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2983 1.681 48 1175 1.681 48
".M1+M2+M3_2_Mh39VY4wllhr_YN1pyYH-g==" 2984 1.726 49 1176 1.726 49
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 "20260620" "20260623" "20260627"
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
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.
"20260620" "20260610" "20260623"
trip_headsign_matches_intermediate_stop INFO 180

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 180 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.
490 "90575" "Orla" "22" 11 "23"
492 "90577" "Orla" "22" 11 "23"
494 "90579" "Orla" "22" 11 "23"
496 "90581" "Orla" "22" 11 "23"
498 "90583" "Orla" "22" 11 "23"
500 "90585" "Orla" "22" 11 "23"
502 "90587" "Orla" "22" 11 "23"
504 "90589" "Orla" "22" 11 "23"
506 "90591" "Orla" "22" 11 "23"
510 "90595" "Orla" "22" 11 "23"
512 "90597" "Orla" "22" 11 "23"
514 "90599" "Orla" "22" 11 "23"
516 "90601" "Orla" "22" 11 "23"
518 "90603" "Orla" "22" 11 "23"
520 "90605" "Orla" "22" 11 "23"
522 "90607" "Orla" "22" 11 "23"
524 "90609" "Orla" "22" 11 "23"
526 "90611" "Orla" "22" 11 "23"
529 "90721" "Orla" "22" 11 "23"
531 "90723" "Orla" "22" 11 "23"
533 "90725" "Orla" "22" 11 "23"
535 "90727" "Orla" "22" 11 "23"
537 "90729" "Orla" "22" 11 "23"
539 "90731" "Orla" "22" 11 "23"
541 "90733" "Orla" "22" 11 "23"
543 "90735" "Orla" "22" 11 "23"
545 "90737" "Orla" "22" 11 "23"
549 "90741" "Orla" "22" 11 "23"
551 "90743" "Orla" "22" 11 "23"
553 "90745" "Orla" "22" 11 "23"
555 "90747" "Orla" "22" 11 "23"
557 "90749" "Orla" "22" 11 "23"
559 "90751" "Orla" "22" 11 "23"
561 "90753" "Orla" "22" 11 "23"
563 "90755" "Orla" "22" 11 "23"
565 "90757" "Orla" "22" 11 "23"
568 "90867" "Orla" "22" 11 "23"
570 "90869" "Orla" "22" 11 "23"
572 "90871" "Orla" "22" 11 "23"
574 "90873" "Orla" "22" 11 "23"
576 "90875" "Orla" "22" 11 "23"
578 "90877" "Orla" "22" 11 "23"
580 "90879" "Orla" "22" 11 "23"
582 "90881" "Orla" "22" 11 "23"
584 "90883" "Orla" "22" 11 "23"
588 "90887" "Orla" "22" 11 "23"
590 "90889" "Orla" "22" 11 "23"
592 "90891" "Orla" "22" 11 "23"
594 "90893" "Orla" "22" 11 "23"
596 "90895" "Orla" "22" 11 "23"
unknown_column INFO 2

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.
"trips.txt" "brigade" 6
"feed_info.txt" "feed_timezone" 3