syncromatics-mvrta — Source Data Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-06-11T22:24:27Z,
for the dataset file:///shared/syncromatics-mvrta_04c39d67.zip. No country code was provided.

Use this report alongside our documentation.

A new version of the Canonical GTFS Schedule validator is available! Please update to get the latest/best validation results.

Summary

Agencies included


Feed Info


Publisher Name:
GMV Syncromatics
Feed Email:
support@gmvsync.com
Feed Language:
English
Feed Start Date:
2026-05-31
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: 29
  • Shapes: 61
  • Stops: 837
  • Trips: 1851

Specification Compliance report

1414 notices reported (0 errors, 1411 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" 296 "stop_name" "BJ's "
"stops.txt" 584 "stop_name" "N Main & Balmoral "
"stops.txt" 608 "stop_name" "Andover Street & Beacon Street "
"stops.txt" 635 "stop_name" "Planet Fitness "
"stops.txt" 671 "stop_name" "Village at Brickell Hill "
"stops.txt" 722 "stop_name" "Broadway & Haverhill St "
"stops.txt" 749 "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 1160

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 1160 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" 42
"stops.txt" "stop_name" "PLEASANT CIRCLE" 44
"stops.txt" "stop_name" "AMAZON DISTRIBUTION CENTER" 766
"stops.txt" "stop_name" "PRINCESTON NORTH ANDOVER" 774
"stops.txt" "stop_name" "NORTH ANDOVER SENIOR CENTER" 775
"stops.txt" "stop_name" "200 SUTTON STREET" 776
"stops.txt" "stop_name" "200 SUTTON STREET" 777
"stops.txt" "stop_name" "CHARDWICK PARK" 778
"stops.txt" "stop_name" "NORTH ANDOVER SENIOR CENTER" 779
"stops.txt" "stop_name" "OSGOOD CROSSING" 780
"stops.txt" "stop_name" "RITE AID" 781
"stops.txt" "stop_name" "ANNA JAQUES" 788
"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 via AMAZON/WARD HILL" 6
"trips.txt" "trip_headsign" "HAVERHILL TRANSIT CENTER" 7
"trips.txt" "trip_headsign" "SALISBURY BEACH" 10
"trips.txt" "trip_headsign" "BEACON ST/MT VERNON" 11
"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" "LOWELL via TOWER HILL" 26
"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" "VILLAGE MALL via BROADWAY" 33
"trips.txt" "trip_headsign" "VILLAGE MALL via BROADWAY" 34
"trips.txt" "trip_headsign" "VILLAGE MALL via BROADWAY" 35
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 37
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 38
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 41
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 42
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 43
"trips.txt" "trip_headsign" "N ANDOVER MALL via PARKER ST" 44
"trips.txt" "trip_headsign" "BEACON ST/MT VERNON" 45
"trips.txt" "trip_headsign" "THE LOOP via PROSPECT HILL" 48
"trips.txt" "trip_headsign" "LOWELL via TOWER HILL" 49
"trips.txt" "trip_headsign" "LOWELL via TOWER HILL" 54
"trips.txt" "trip_headsign" "LOWELL via TOWER HILL" 55
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 58
"trips.txt" "trip_headsign" "HOLY FAMILY HOSP via LGH" 59
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.
"7070" 30 "#120AFF" "#3643FF"
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"
"6983" 28 "25" "25 Methuen Crosstown Merrimack Plaza / Dana Farber"
"6985" 29 "28" "28 Salem New Hampshire / Tuscan Village"
route_short_name_too_long WARNING 1

route_short_name_too_long

Short name of a route is too long (more than 12 characters).

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`.
"7070" 30 "Amesbury Town Park"
same_name_and_description_for_route WARNING 1

same_name_and_description_for_route

Same name and description for route.

The GTFS spec defines routes.txt route_desc as:

Description of a route that provides useful, quality information. Do not simply duplicate the name of the route.

See the GTFS and GTFS Best Practices links below for more examples of how to populate the route_short_name, route_long_name, and route_desc fields.

You can see more about this notice here.

csvRowNumber (?) The row number of the faulty record. routeId (?) The id of the faulty record. routeDesc (?) The `routes.routes_desc` of the faulty record. specifiedField (?) Either `route_short_name` or `route_long_name`.
30 "7070" "Amesbury Town Park" "route_short_name"
stop_without_stop_time WARNING 74

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 74 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"
21 "10145882" "Union & Market"
34 "11163892" "Amesbury Road and Airport Lane"
41 "11562377" "KARMA"
76 "12181561" "Shaws"
77 "12185025" "Town Park"
79 "8900074" "Nathans at Wash. St and Wash. Ave"
90 "8900373" "Broadway and Carleton St, Haverhill"
101 "8900839" "Elliot Place"
102 "8900841" "Water St and Main St"
122 "8901176" "Water St and Main St"
124 "8901179" "Bank of America (191 Merrimack Street)"
134 "8901969" "Waverly Rd and Winthrop Ave"
136 "8901973" "Haverhill Street & Sterling Lane"
141 "8901981" "206 N Main St"
145 "8901985" "School St and Essex St"
148 "8902612" "Broadway St and Wolcott Ave"
156 "8902621" "Main St and William St"
164 "8902873" "Union St and Kenilworth St"
165 "8902874" "South St and Union St"
169 "8902878" "Broadway St ad Merrimack St - 21 S Broadway"
177 "8903490" "Union St and Merrimack St - New Balance"
189 "8903504" "Peters St and Turnpike St"
190 "8904069" "Peters St and Turnpike St"
203 "8904083" "330 Merrimack St"
206 "8904086" "Union St and Merrimack St - New Balance"
213 "8904410" "Grove and High, Haverhill"
214 "8904416" "Hilldale Avenue & Cliff Street"
219 "8904421" "Monument St and Broadway St, Haverhill"
220 "8904835" "Monument St and Broadway St, Haverhill"
227 "8904849" "Winter Street and Lafayette Square"
236 "8910078" "Broadway and Park Street"
237 "8910081" "Broadway St and Common St - 90 Broadway"
245 "8912281" "Hunter Ave"
254 "8914947" "Beacon & Mt Vernon"
354 "8932262" "786 River St (99 Restaurant)"
356 "8932264" "Hunter Ave"
366 "8932278" "Montgomery & Jackson"
383 "8934176" "before 495 Overpass Bridge"
384 "8934177" "Brickett Lane"
393 "8934914" "Main Street & Columbia Place"
399 "8934923" "Merrimack St - Pentucket Bank"
412 "8936774" "Essex Plaza"
422 "8936787" "Merrimack Plaza, Methuen"
426 "8937260" "Merrimack Plaza, Methuen"
433 "8937269" "Essex Plaza"
444 "8937730" "Lawrence Street & Locust Road"
472 "8938280" "150 North St"
475 "8938283" "Minuteman Rd and River Rd"
479 "8938669" "Minuteman Rd and River Rd"
trip_distance_exceeds_shape_distance_below_threshold WARNING 145

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 145 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.
"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
"6149458" "30453" 18551.847284435054 18551.84728443505 0.0
"6149476" "30495" 8970.039363759894 8970.039363759892 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
"6149610" "30453" 18551.847284435054 18551.84728443505 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
"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
"6149707" "30453" 18551.847284435054 18551.84728443505 0.0
"6149708" "30453" 18551.847284435054 18551.84728443505 0.0
"6149709" "30453" 18551.847284435054 18551.84728443505 0.0
"6149710" "30453" 18551.847284435054 18551.84728443505 0.0
"6149711" "30453" 18551.847284435054 18551.84728443505 0.0
"6149717" "30453" 18551.847284435054 18551.84728443505 0.0
"6149718" "30453" 18551.847284435054 18551.84728443505 0.0
"6149725" "30453" 18551.847284435054 18551.84728443505 0.0
"6149740" "30453" 18551.847284435054 18551.84728443505 0.0
"6149777" "30495" 8970.039363759894 8970.039363759892 0.0
"6149778" "30453" 18551.847284435054 18551.84728443505 0.0
"6149779" "30453" 18551.847284435054 18551.84728443505 0.0
"6149783" "30453" 18551.847284435054 18551.84728443505 0.0
"6149784" "30453" 18551.847284435054 18551.84728443505 0.0
"6149785" "30453" 18551.847284435054 18551.84728443505 0.0
"6149786" "30453" 18551.847284435054 18551.84728443505 0.0
"6149787" "30453" 18551.847284435054 18551.84728443505 0.0
"6149788" "30453" 18551.847284435054 18551.84728443505 0.0
"6149789" "30453" 18551.847284435054 18551.84728443505 0.0
"6149790" "30453" 18551.847284435054 18551.84728443505 0.0
"6149791" "30453" 18551.847284435054 18551.84728443505 0.0
"6149792" "30453" 18551.847284435054 18551.84728443505 0.0
"6149795" "30453" 18551.847284435054 18551.84728443505 0.0
"6149876" "30453" 18551.847284435054 18551.84728443505 0.0
"6149980" "30512" 38258.715812164395 38258.67724860395 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"