GTFS Schedule Validation Report

This report was generated by the Canonical GTFS Schedule validator, version 7.1.0 at 2026-02-04T02:30:54Z,
for the dataset file:///shared/mwasalat_88e531c9.zip. No country code was provided.

Use this report alongside our documentation.

Summary

Agencies included


  • Oman National Transport Company

Feed Info


Publisher Name:
Oman National Transport Company
Publisher URL:
http://mwasalat.om
Feed Email:
N/A
Feed Language:
English
Feed Start Date:
2025-10-01
Feed End Date:
2026-03-01

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. translations.txt
  10. trips.txt

Counts


  • Agencies: 1
  • Blocks: 0
  • Routes: 0
  • Shapes: 107
  • Stops: 999
  • Trips: 3548

Specification Compliance report

575 notices reported (67 errors, 504 warnings, 4 infos)

Notice Code Severity Total
duplicate_key ERROR 3

duplicate_key

Duplicated entity.

The values of the given key and rows are duplicates.

You can see more about this notice here.

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.
"translations.txt" 1146 1263 "table_name,field_name,language,field_value" "stops,stop_name,ar_BH,Ruwi Roundabout"
"translations.txt" 772 2787 "table_name,field_name,language,field_value" "stops,stop_name,ar_BH,Al Nahdha Hospital"
"translations.txt" 791 3176 "table_name,field_name,language,field_value" "stops,stop_name,ar_BH,Al Hamriya Roundabout"
invalid_color ERROR 64

invalid_color

A field contains an invalid color value.

A color must be encoded as a six-digit hexadecimal number. The leading "#" is not included.

Example: FFFFFF for white, 000000 for black or 0039A6 for the A,C,E lines in NYC MTA.

You can see more about this notice here.

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

filename (?) The name of the faulty file. csvRowNumber (?) The row of the faulty record. fieldName (?) Faulty record's field name. fieldValue (?) Faulty value.
"routes.txt" 2 "route_text_color" "0"
"routes.txt" 3 "route_text_color" "0"
"routes.txt" 4 "route_text_color" "0"
"routes.txt" 5 "route_text_color" "0"
"routes.txt" 6 "route_text_color" "0"
"routes.txt" 7 "route_text_color" "0"
"routes.txt" 8 "route_text_color" "0"
"routes.txt" 9 "route_text_color" "0"
"routes.txt" 10 "route_text_color" "0"
"routes.txt" 11 "route_text_color" "0"
"routes.txt" 12 "route_text_color" "0"
"routes.txt" 13 "route_text_color" "0"
"routes.txt" 14 "route_text_color" "0"
"routes.txt" 15 "route_text_color" "0"
"routes.txt" 16 "route_text_color" "0"
"routes.txt" 17 "route_text_color" "0"
"routes.txt" 18 "route_text_color" "0"
"routes.txt" 19 "route_text_color" "0"
"routes.txt" 20 "route_text_color" "0"
"routes.txt" 21 "route_text_color" "0"
"routes.txt" 22 "route_text_color" "0"
"routes.txt" 23 "route_text_color" "0"
"routes.txt" 24 "route_text_color" "0"
"routes.txt" 25 "route_text_color" "0"
"routes.txt" 26 "route_text_color" "0"
"routes.txt" 27 "route_text_color" "0"
"routes.txt" 28 "route_color" "0"
"routes.txt" 28 "route_text_color" "0"
"routes.txt" 29 "route_color" "0"
"routes.txt" 29 "route_text_color" "0"
"routes.txt" 30 "route_text_color" "0"
"routes.txt" 31 "route_text_color" "0"
"routes.txt" 32 "route_text_color" "0"
"routes.txt" 33 "route_text_color" "0"
"routes.txt" 34 "route_text_color" "0"
"routes.txt" 35 "route_text_color" "0"
"routes.txt" 36 "route_text_color" "0"
"routes.txt" 37 "route_text_color" "0"
"routes.txt" 38 "route_text_color" "0"
"routes.txt" 39 "route_text_color" "0"
"routes.txt" 40 "route_text_color" "0"
"routes.txt" 41 "route_text_color" "0"
"routes.txt" 42 "route_text_color" "0"
"routes.txt" 43 "route_text_color" "0"
"routes.txt" 44 "route_text_color" "0"
"routes.txt" 45 "route_text_color" "0"
"routes.txt" 46 "route_text_color" "0"
"routes.txt" 47 "route_text_color" "0"
"routes.txt" 48 "route_text_color" "0"
"routes.txt" 49 "route_text_color" "0"
expired_calendar WARNING 1

expired_calendar

Dataset should not contain date ranges for services that have already expired.

This warning takes into account the calendar_dates.txt file as well as the calendar.txt file.

You can see more about this notice here.

csvRowNumber (?) The row of the faulty record. serviceId (?) The service id of the faulty record.
2 "0"
feed_expiration_date30_days WARNING 1

feed_expiration_date30_days

Dataset should cover at least the next 30 days of service.

At any time, the GTFS dataset should cover at least the next 30 days of service, and ideally for as long as the operator is confident that the schedule will continue to be operated.

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 "20260204" "20260301" "20260306"
leading_or_trailing_whitespaces WARNING 501

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.

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

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" 4 "stop_name" "Fanja Hights "
"stops.txt" 45 "stop_name" "SQU Hospital "
"stops.txt" 46 "stop_name" "Al Nahdha Hospital "
"stops.txt" 48 "stop_name" "Yanqul - Khadal "
"stops.txt" 60 "stop_name" "Yanqul - Opposite Jamea Al Sultan Qaboos "
"stops.txt" 66 "stop_name" "Al Sharadi - Opposite Masjid Khalid Bin Waleed "
"stops.txt" 77 "stop_name" "Liwa - Ghadfan Pedestrian Bridge "
"stops.txt" 92 "stop_name" "Al Amri Centre "
"stops.txt" 103 "stop_name" "Salalah - Samharam Resorts "
"stops.txt" 108 "stop_name" "Al Abiyad - Shell Fuel St. "
"stops.txt" 109 "stop_name" "Al Abiyad - Opp. Shell Fuel St. "
"stops.txt" 120 "stop_name" "Al Khoudh Souq "
"stops.txt" 123 "stop_name" "Opposite Al Khoudh Souq "
"stops.txt" 148 "stop_name" "Opposite Al Mouj Golf "
"stops.txt" 149 "stop_name" "Fujairah - Etisalat "
"stops.txt" 152 "stop_name" "Sinaw R/A - Shell Fuel Stn. "
"stops.txt" 158 "stop_name" "Fujairah - Choithrams Supermarket "
"stops.txt" 169 "stop_name" "Al Mouj Golf "
"stops.txt" 181 "stop_name" "Jamea Ghaffar "
"stops.txt" 185 "stop_name" "Opposite Al Khoudh Police Station "
"stops.txt" 191 "stop_name" "Al Khoudh Police Station "
"stops.txt" 198 "stop_name" "Opposite Al Mabelah Police Station "
"stops.txt" 244 "stop_name" "Opposite Jamea Othman Bin Affan "
"stops.txt" 299 "stop_name" "Omani Women's Association "
"stops.txt" 340 "stop_name" " Al Burj St - Bank Muscat"
"stops.txt" 349 "stop_name" "Al Yahmadi "
"stops.txt" 351 "stop_name" "Al Nadi Roundabout "
"stops.txt" 358 "stop_name" "Wadi Kabir - Nesto Hypermarket "
"stops.txt" 362 "stop_name" "Jamea Othman Bin Affan "
"stops.txt" 364 "stop_name" "Opposite Al Amerat Health Center "
"stops.txt" 370 "stop_name" "Wadi Hattat - Souq "
"stops.txt" 374 "stop_name" " Al Mabelah - Block 3"
"stops.txt" 380 "stop_name" "Wadi Kabir - International School "
"stops.txt" 381 "stop_name" "Seeb - Opposite NMC Medical Center "
"stops.txt" 382 "stop_name" " Al Mabelah - Block 4"
"stops.txt" 389 "stop_name" "Al Maamurah "
"stops.txt" 390 "stop_name" "Falaj Al Sham "
"stops.txt" 395 "stop_name" "Masjid Othman bin Affan "
"stops.txt" 401 "stop_name" "Seeb - NMC Medical Center "
"stops.txt" 404 "stop_name" "Panorama Mall "
"stops.txt" 407 "stop_name" " Oman Medical Association"
"stops.txt" 409 "stop_name" "Al Duraiz - Shell Fuel Stn. "
"stops.txt" 422 "stop_name" "Al Eshraq Roundabout "
"stops.txt" 425 "stop_name" "Opposite Jamea Sultan Taimur bin Faisal "
"stops.txt" 441 "stop_name" "Al Mabelah Police Station "
"stops.txt" 449 "stop_name" "Opposite Philex Pharmaceutical SFZ "
"stops.txt" 456 "stop_name" "Hazim Bin Hammam School "
"stops.txt" 465 "stop_name" "Al Ghaftain - Opposite Shell Fuel Stn. "
"stops.txt" 467 "stop_name" "Al Ghaftain - Shell Fuel Stn. "
"stops.txt" 471 "stop_name" "Abu Madab - Al Maha Fuel Stn. "
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
unknown_column INFO 4

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" "duty" 11
"trips.txt" "duty_sequence_number" 12
"trips.txt" "run_sequence_number" 13
"trips.txt" "trip_type" 14