GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-01-23T14:59:21Z,
for the dataset file:///shared/merrimack-valley-rta.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


  • Merrimack Valley Transit

Feed Info


Publisher Name:
Trillium Solutions, Inc.
Feed Email:
support+merrimackvalley-ma-us@trilliumtransit.com
Feed Language:
English
Feed Start Date:
2026-01-08
Feed End Date:
2026-07-06

Files included


  1. agency.txt
  2. areas.txt
  3. booking_rules.txt
  4. calendar.txt
  5. calendar_attributes.txt
  6. calendar_dates.txt
  7. directions.txt
  8. fare_attributes.txt
  9. fare_rules.txt
  10. farezone_attributes.txt
  11. feed_info.txt
  12. frequencies.txt
  13. linked_datasets.txt
  14. location_groups.txt
  15. routes.txt
  16. runcut.txt
  17. shapes.txt
  18. stop_attributes.txt
  19. stop_times.txt
  20. stops.txt
  21. timetable_stop_order.txt
  22. timetables.txt
  23. transfers.txt
  24. trips.txt

Counts


  • Agencies: 1
  • Blocks: 171
  • Routes: 26
  • Shapes: 70
  • Stops: 1110
  • Trips: 2244

Specification Compliance report

359 notices reported (0 errors, 317 warnings, 42 infos)

Notice Code Severity Total
equal_shape_distance_diff_coordinates_distance_below_threshold WARNING 2

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.
"p_1438178" 16947 3996.0758864199997 219 16946 3996.0758864199997 218 1.7621047928049192E-7
"p_1441171" 31406 3996.0758864199997 219 31405 3996.0758864199997 218 1.7621047928049192E-7
mixed_case_recommended_field WARNING 26

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.
"routes.txt" "route_long_name" "ESSEX CROSSTOWN / ESSEX PLAZA" 2
"routes.txt" "route_long_name" "LAWRENCE-HAVERHILL VIA THE LOOP" 3
"routes.txt" "route_long_name" "VILLAGE MALL VIA BROADWAY" 4
"routes.txt" "route_long_name" "LAWRENCE-HAVERHILL-NEWBURYPORT LIMITED" 5
"routes.txt" "route_long_name" "LAWRENCE CROSSTOWN" 6
"routes.txt" "route_long_name" "STATELINE PLAZA/PLAISTOW" 7
"routes.txt" "route_long_name" "LAWRENCE-HAVERHILL VIA AMAZON/WARD HILL" 8
"routes.txt" "route_long_name" "WESTGATE PLAZA VIA HILLDALE" 9
"routes.txt" "route_long_name" "WESTGATE PLAZA VIA WASHINGTON STREET" 10
"routes.txt" "route_long_name" "SALISBURY BEACH VIA AMESBURY" 11
"routes.txt" "route_long_name" "RIVERSIDE/GROVELAND" 12
"routes.txt" "route_long_name" "AMESBURY/COSTELLO" 13
"routes.txt" "route_long_name" "ANDOVER SQUARE VIA SOUTH BROADWAY" 14
"routes.txt" "route_long_name" "SALISBURY BEACH" 15
"routes.txt" "route_long_name" "ANDOVER SHUTTLE" 16
"routes.txt" "route_long_name" "BUTTONWOODS EXPRESS" 17
"routes.txt" "route_long_name" "LAWRENCE-LOWELL" 18
"routes.txt" "route_long_name" "IRS/RAYTHEON" 19
"routes.txt" "route_long_name" "BEACON STREET SPECIAL" 20
"routes.txt" "route_long_name" "NORTH ANDOVER/WOODRIDGE" 21
"routes.txt" "route_long_name" "THE LOOP VIA PROSPECT HILL" 22
"routes.txt" "route_long_name" "MERRIMAC PLAZA/DANA FARBER VIA WATER STREET" 23
"routes.txt" "route_long_name" "HOLY FAMILY HOSPITAL VIA LAWRENCE GENERAL" 24
"routes.txt" "route_long_name" "BEACON STREET/MOUNT VERNON" 25
"routes.txt" "route_long_name" "NORTH ANDOVER MALL VIA PARKER STREET" 26
"routes.txt" "route_long_name" "MERRIMACK COLLEGE VIA SOUTH UNION STREET/NORTH ANDOVER MALL" 27
route_color_contrast WARNING 6

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.
"77548" 2 "#99D3F3" "#FFFFFF"
"10737" 6 "#FD9ACB" "#FFFFFF"
"76301" 15 "#FFC967" "#FFFFFF"
"10731" 16 "#FFD52D" "#FFFFFF"
"10750" 24 "#FEC00D" "#FFFFFF"
"10751" 25 "#F5B496" "#FFFFFF"
stop_without_stop_time WARNING 283

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 283 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.
2 "2448720" "Anna Jacques Hospital"
4 "2448722" "Merrimac Square"
7 "2448725" "Prospect Street & E Haverhill Street"
9 "2448727" "Chestnut Court"
13 "2448731" "Sawyer Street & Lowell Street"
15 "2448733" "Cambridge Street & Somerset Street"
18 "2448736" "Port Plaza"
21 "2448739" "North Andover High School"
22 "2448740" "Osgood Landing"
24 "2448742" "Hawley Street"
25 "2448743" "Broadway & Andover St"
26 "2448744" "Merrimack Plaza - Brooks"
27 "2448745" "Mt Vernon Street & Jefferson Street"
28 "2448746" "West Mill on High Street"
29 "2448747" "Jackson Street & Swan Street"
31 "2448749" "Main Street & Brookline Avenue"
35 "2448753" "Washington Square Transit Center"
38 "2448756" "Merrimack Street & Pleasant Valley Street"
39 "2448757" "West Mill on High Street"
41 "2448759" "Haverhill Medical Center"
42 "2448760" "Rocky Hill Road"
43 "2448761" "Marston Street & Allston Street"
48 "2448767" "Buckley Transportation Center"
49 "2448768" "Glenn Street & Shepard Street"
50 "2448769" "Plaza 114 at N Parish Road"
52 "2448771" "Doctors Park"
54 "2448773" "Frye Circle"
56 "2448775" "Beach Rd & Lincoln Ave - Salisbury Center"
58 "2448778" "Merrimack Street & Pleasant Valley Street"
63 "2448783" "Lawrence General Hospital - Main Entrance"
64 "2448784" "Buckley Transportation Center"
68 "2448788" "James Steam Mill"
70 "2448790" "Andover Center"
71 "2448791" "Park Street MBTA Station"
74 "2448794" "Broadway & Andover St"
77 "2448797" "Broadway & Carleton Street"
78 "2448798" "North Andover Commons"
79 "2448799" "Woodridge Housing"
80 "2448800" "Summer Street & Allen Street"
82 "2448802" "United Linen & La Frutería Market"
83 "2448803" "Massachusetts Avenue"
85 "2448805" "Park Place South"
86 "2448806" "Faith Lutheran Church Park & Ride"
88 "2448808" "Broadway & Essex Street"
95 "2448815" "Methuen Square"
96 "2448817" "Andover Center"
97 "2448818" "Transportation Building in Park Square"
99 "2448820" "Salem Street"
100 "2448821" "Oakland Ave & Railroad Street"
101 "2448822" "Government Center (Congress)"
unknown_column INFO 34

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.
"areas.txt" "wkt" 2
"agency.txt" "tts_agency_name" 8
"calendar.txt" "service_name" 2
"calendar_dates.txt" "holiday_name" 3
"feed_info.txt" "feed_license" 5
"feed_info.txt" "feed_id" 10
"routes.txt" "min_headway_minutes" 11
"routes.txt" "eligibility_restricted" 12
"routes.txt" "tts_route_short_name" 15
"routes.txt" "tts_route_long_name" 16
"stop_times.txt" "start_service_area_id" 11
"stop_times.txt" "end_service_area_id" 12
"stop_times.txt" "start_service_area_radius" 13
"stop_times.txt" "end_service_area_radius" 14
"stop_times.txt" "mean_duration_factor" 21
"stop_times.txt" "mean_duration_offset" 22
"stop_times.txt" "safe_duration_factor" 23
"stop_times.txt" "safe_duration_offset" 24
"stop_times.txt" "tts_stop_headsign" 25
"stop_times.txt" "min_arrival_time" 26
"stop_times.txt" "max_departure_time" 27
"stops.txt" "position" 13
"stops.txt" "direction" 14
"trips.txt" "trip_type" 11
"trips.txt" "drt_max_travel_time" 12
"trips.txt" "drt_avg_travel_time" 13
"trips.txt" "drt_advance_book_min" 14
"trips.txt" "drt_pickup_message" 15
"trips.txt" "drt_drop_off_message" 16
"trips.txt" "continuous_pickup_message" 17
"trips.txt" "continuous_drop_off_message" 18
"trips.txt" "tts_trip_headsign" 19
"trips.txt" "tts_trip_short_name" 20
"location_groups.txt" "location_id" 2
unknown_file INFO 8

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"calendar_attributes.txt"
"directions.txt"
"farezone_attributes.txt"
"runcut.txt"
"stop_attributes.txt"
"timetable_stop_order.txt"
"timetables.txt"
"linked_datasets.txt"