GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-05-04T15:37:40Z,
for the dataset file:///shared/syncromatics-mvrta_f5a47b2c.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


Feed Info


Publisher Name:
GMV Syncromatics
Feed Email:
support@gmvsync.com
Feed Language:
English
Feed Start Date:
2026-04-30
Feed End Date:
N/A

Files included


  1. agency.txt
  2. calendar.txt
  3. calendar_attributes.txt
  4. directions.txt
  5. feed_info.txt
  6. realtime_routes.txt
  7. routes.txt
  8. shapes.txt
  9. stop_times.txt
  10. stops.txt
  11. trips.txt

Counts


  • Agencies: 1
  • Blocks: 176
  • Routes: 28
  • Shapes: 63
  • Stops: 868
  • Trips: 1851

Specification Compliance report

731 notices reported (0 errors, 728 warnings, 3 infos)

Notice Code Severity Total
leading_or_trailing_whitespaces WARNING 8

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" 312 "stop_name" "BJ's "
"stops.txt" 606 "stop_name" "N Main & Balmoral "
"stops.txt" 632 "stop_name" "Andover Street & Beacon Street "
"stops.txt" 659 "stop_name" "Planet Fitness "
"stops.txt" 695 "stop_name" "Village at Brickell Hill "
"stops.txt" 751 "stop_name" "Broadway & Haverhill St "
"stops.txt" 778 "stop_name" "Jackson street and Fern Street "
"routes.txt" 29 "route_long_name" "28 Salem New Hampshire / Tuscan Village "
missing_feed_info_date WARNING 1

missing_feed_info_date

One of feed_start_date or feed_end_date is specified, but not both.

Even though feed_info.start_date and feed_info.end_date are optional, if one field is provided the second one should also be provided.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. fieldName (?) Either `feed_end_date` or `feed_start_date`.
2 "feed_end_date"
missing_recommended_field WARNING 1

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.

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) The name of the missing field.
"feed_info.txt" 2 "feed_end_date"
mixed_case_recommended_field WARNING 392

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 392 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.
"stops.txt" "stop_name" "STOP & SHOP" 49
"stops.txt" "stop_name" "PLEASANT CIRCLE" 51
"stops.txt" "stop_name" "AMAZON DISTRIBUTION CENTER" 795
"stops.txt" "stop_name" "PRINCESTON NORTH ANDOVER" 803
"stops.txt" "stop_name" "NORTH ANDOVER SENIOR CENTER" 804
"stops.txt" "stop_name" "200 SUTTON STREET" 805
"stops.txt" "stop_name" "200 SUTTON STREET" 806
"stops.txt" "stop_name" "CHARDWICK PARK" 807
"stops.txt" "stop_name" "NORTH ANDOVER SENIOR CENTER" 808
"stops.txt" "stop_name" "OSGOOD CROSSING" 809
"stops.txt" "stop_name" "RITE AID" 810
"stops.txt" "stop_name" "ANNA JAQUES" 817
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 3
"trips.txt" "trip_headsign" "SALISBURY BEACH" 4
"trips.txt" "trip_headsign" "SALISBURY BEACH" 5
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT CENTER" 7
"trips.txt" "trip_headsign" "SALISBURY BEACH" 10
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 13
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 14
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 17
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 18
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 19
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 20
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 21
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 22
"trips.txt" "trip_headsign" "RIVERSIDE GROVELAND" 23
"trips.txt" "trip_headsign" "AMESBURY COSTELLO" 24
"trips.txt" "trip_headsign" "SALISBURY BEACH" 27
"trips.txt" "trip_headsign" "NEWBURYPORT RAIL STATION" 29
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 31
"trips.txt" "trip_headsign" "SALISBURY BEACH" 32
"trips.txt" "trip_headsign" "114 N.ANDOVER MALL" 44
"trips.txt" "trip_headsign" "114 N.ANDOVER MALL" 66
"trips.txt" "trip_headsign" "114 N.ANDOVER MALL" 67
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT CENTER" 68
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 84
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 85
"trips.txt" "trip_headsign" "AMESBURY COSTELLO" 86
"trips.txt" "trip_headsign" "SALISBURY BEACH" 87
"trips.txt" "trip_headsign" "STATELINE PLAZA AND PLAISTOW" 96
"trips.txt" "trip_headsign" "AMESBURY COSTELLO" 97
"trips.txt" "trip_headsign" "AMESBURY COSTELLO" 98
"trips.txt" "trip_headsign" "SALISBURY VIA AMESBURY" 99
"trips.txt" "trip_headsign" "SALISBURY VIA AMESBURY" 100
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT" 114
"trips.txt" "trip_headsign" "SALISBURY BEACH" 117
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT CENTER" 118
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT CENTER" 119
"trips.txt" "trip_headsign" "RIVERSIDE GROVELAND" 124
"trips.txt" "trip_headsign" "SALISBURY BEACH" 126
route_long_name_contains_short_name WARNING 19

route_long_name_contains_short_name

Long name should not contain short name for a single route.

In routes.txt, route_long_name should not contain the value for route_short_name, because when both are provided, they are often combined by transit applications. Note that only one of the two fields is required. If there is no short name used for a route, use route_long_name only.

Good examples:

route_short_name/route_long_name Dataset
"N"/"Judah" Muni San Fransisco
"6"/"ML King Jr Blvd" Trimet Portland Streetcar
"55"/"Boulevard Saint Laurent" STM Montreal
"1"/"Rangiora/Cashmere" Metro Christchurch

Bad examples:

route_short_name/route_long_name
"604"/"604"
"14"/"Route 14"
"2"/"Route 2: Bellows Falls In-Town"

You can see more about this notice here.

routeId (?) The id of the faulty record. csvRowNumber (?) The row number of the faulty record. routeShortName (?) The faulty record's `route_short_name`. routeLongName (?) The faulty record's `route_long_name`.
"6162" 2 "16" "16 - Washington Street/Westgate Plaza"
"6163" 3 "18" "18 - Riverside/Groveland"
"6164" 4 "21" "21 - Andover Shuttle"
"6165" 5 "15" "15 - Hilldale/Westgate"
"6166" 6 "26" "26 - IRS Raytheon"
"6167" 7 "14" "14 - Bradford/Ward Hill"
"6169" 9 "13" "13 - Plaistow via Main Street/North Avenue"
"6170" 10 "27" "27 - Beacon St Tripper"
"6171" 11 "22" "22 - Buttonwoods Express"
"6173" 13 "17" "17 -Haverhill-Sallisbury Beach via Amesbury"
"6174" 14 "19" "19 - Newburyport CR-Amesbury"
"6175" 15 "20" "20 - Newburyport CR-Salisbury"
"6183" 22 "10" "10 - Methuen Square via Broadway"
"6184" 23 "24" "24 - Lawrence-Lowell"
"6185" 24 "12" "12 - Lawrence Crosstown"
"6473" 26 "11" "11 - Newburyport Limited"
"6813" 27 "0" "0 - Essex Crosstown Essex Plaza Effective 09-08-25"
"6983" 28 "25" "25 Methuen Crosstown Merrimack Plaza / Dana Farber"
"6985" 29 "28" "28 Salem New Hampshire / Tuscan Village"
stop_without_stop_time WARNING 105

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 105 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 "10036668" "Butcher Boy"
3 "10050304" "Duffys Diner"
22 "10145881" "Union & Market"
23 "10145882" "Union & Market"
25 "10278731" "Hampshire St & Essex St"
30 "11086531" "East & Pinewood"
31 "11086532" "Lawrence & Fern"
32 "11086533" "Lawrence & Myrtle"
33 "11086982" "McGovern TC Platform/Plarforma A"
41 "11163892" "Amesbury Road and Airport Lane"
48 "11562377" "KARMA"
84 "8900074" "Nathans at Wash. St and Wash. Ave"
95 "8900373" "Broadway and Carleton St, Haverhill"
106 "8900839" "Elliot Place"
107 "8900841" "Water St and Main St"
127 "8901176" "Water St and Main St"
129 "8901179" "Bank of America (191 Merrimack Street)"
130 "8901598" "Chestnut Court, Andover"
136 "8901613" "Haverhill St - Doctors' Offices"
137 "8901614" "Doctors' Park, Andover"
142 "8901969" "Waverly Rd and Winthrop Ave"
144 "8901971" "Doctors' Park, Andover"
145 "8901973" "Haverhill Street & Sterling Lane"
150 "8901981" "206 N Main St"
154 "8901985" "School St and Essex St"
156 "8902607" "Buckley Transportation Center, Lawrence"
158 "8902609" "499 Essex St"
159 "8902610" "Broadway St and Essex St"
160 "8902612" "Broadway St and Wolcott Ave"
168 "8902621" "Main St and William St"
176 "8902873" "Union St and Kenilworth St"
177 "8902874" "South St and Union St"
181 "8902878" "Broadway St ad Merrimack St - 21 S Broadway"
182 "8902879" "Broadway St and Canal St - 1 Broadway St"
190 "8903490" "Union St and Merrimack St - New Balance"
191 "8903491" "McGovern Transportation Center, Lawrence"
203 "8903504" "Peters St and Turnpike St"
204 "8904069" "Peters St and Turnpike St"
217 "8904083" "330 Merrimack St"
220 "8904086" "Union St and Merrimack St - New Balance"
225 "8904404" "Essex Street & Locust Street"
228 "8904410" "Grove and High, Haverhill"
229 "8904416" "Hilldale Avenue & Cliff Street"
234 "8904421" "Monument St and Broadway St, Haverhill"
235 "8904835" "Monument St and Broadway St, Haverhill"
242 "8904849" "Winter Street and Lafayette Square"
251 "8910078" "Broadway and Park Street"
252 "8910081" "Broadway St and Common St - 90 Broadway"
260 "8912281" "Hunter Ave"
269 "8914947" "Beacon & Mt Vernon"
trip_distance_exceeds_shape_distance_below_threshold WARNING 202

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.

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

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.
"6149329" "24289" 11344.317320994227 11344.317320994129 0.0
"6149330" "24289" 11344.317320994227 11344.317320994129 0.0
"6149335" "24289" 11344.317320994227 11344.317320994129 0.0
"6149352" "24289" 11344.317320994227 11344.317320994129 0.0
"6149358" "30579" 9531.662439600663 9531.662439600632 0.0
"6149359" "30579" 9531.662439600663 9531.662439600632 0.0
"6149360" "30579" 9531.662439600663 9531.662439600632 0.0
"6149364" "30495" 8970.039363759894 8970.039363759892 0.0
"6149365" "30495" 8970.039363759894 8970.039363759892 0.0
"6149381" "30495" 8970.039363759894 8970.039363759892 0.0
"6149382" "30495" 8970.039363759894 8970.039363759892 0.0
"6149387" "30495" 8970.039363759894 8970.039363759892 0.0
"6149395" "30453" 18551.847284435054 18551.84728443505 0.0
"6149396" "30453" 18551.847284435054 18551.84728443505 0.0
"6149397" "30453" 18551.847284435054 18551.84728443505 0.0
"6149398" "30453" 18551.847284435054 18551.84728443505 0.0
"6149414" "30453" 18551.847284435054 18551.84728443505 0.0
"6149426" "30453" 18551.847284435054 18551.84728443505 0.0
"6149429" "30579" 9531.662439600663 9531.662439600632 0.0
"6149442" "24289" 11344.317320994227 11344.317320994129 0.0
"6149451" "24289" 11344.317320994227 11344.317320994129 0.0
"6149452" "24289" 11344.317320994227 11344.317320994129 0.0
"6149453" "24289" 11344.317320994227 11344.317320994129 0.0
"6149455" "24289" 11344.317320994227 11344.317320994129 0.0
"6149456" "24289" 11344.317320994227 11344.317320994129 0.0
"6149458" "30453" 18551.847284435054 18551.84728443505 0.0
"6149467" "30579" 9531.662439600663 9531.662439600632 0.0
"6149476" "30495" 8970.039363759894 8970.039363759892 0.0
"6149483" "30579" 9531.662439600663 9531.662439600632 0.0
"6149505" "30512" 38258.715812164395 38258.67724860395 0.0
"6149506" "30512" 38258.715812164395 38258.67724860395 0.0
"6149581" "30453" 18551.847284435054 18551.84728443505 0.0
"6149583" "30579" 9531.662439600663 9531.662439600632 0.0
"6149608" "30579" 9531.662439600663 9531.662439600632 0.0
"6149610" "30453" 18551.847284435054 18551.84728443505 0.0
"6149620" "30579" 9531.662439600663 9531.662439600632 0.0
"6149623" "30579" 9531.662439600663 9531.662439600632 0.0
"6149633" "24289" 11344.317320994227 11344.317320994129 0.0
"6149666" "30453" 18551.847284435054 18551.84728443505 0.0
"6149667" "30453" 18551.847284435054 18551.84728443505 0.0
"6149668" "30453" 18551.847284435054 18551.84728443505 0.0
"6149670" "24289" 11344.317320994227 11344.317320994129 0.0
"6149671" "24289" 11344.317320994227 11344.317320994129 0.0
"6149674" "30579" 9531.662439600663 9531.662439600632 0.0
"6149675" "30579" 9531.662439600663 9531.662439600632 0.0
"6149679" "30453" 18551.847284435054 18551.84728443505 0.0
"6149680" "30453" 18551.847284435054 18551.84728443505 0.0
"6149681" "30453" 18551.847284435054 18551.84728443505 0.0
"6149682" "30453" 18551.847284435054 18551.84728443505 0.0
"6149683" "30453" 18551.847284435054 18551.84728443505 0.0
unknown_file INFO 3

unknown_file

A file is unknown.

You can see more about this notice here.

filename (?) The name of the unknown file.
"calendar_attributes.txt"
"realtime_routes.txt"
"directions.txt"