>>> mobroute: Building testing/mobroute 0.9.0-r1 (using abuild 3.14.1-r5) started Sat, 18 Jan 2025 08:58:43 +0000 >>> mobroute: Validating /home/buildozer/aports/testing/mobroute/APKBUILD... >>> mobroute: Analyzing dependencies... >>> mobroute: Installing for build: build-base tzdata go sqlite-dev (1/6) Installing tzdata (2024b-r1) (2/6) Installing go (1.23.5-r0) (3/6) Installing sqlite (3.48.0-r0) (4/6) Installing sqlite-libs (3.48.0-r0) (5/6) Installing sqlite-dev (3.48.0-r0) (6/6) Installing .makedepends-mobroute (20250118.085845) Executing busybox-1.37.0-r13.trigger OK: 587 MiB in 112 packages >>> mobroute: Cleaning up srcdir >>> mobroute: Cleaning up pkgdir >>> mobroute: Cleaning up tmpdir >>> mobroute: Fetching https://distfiles.alpinelinux.org/distfiles/edge/mobroute-0.9.0.tar.gz % Total % Received % Xferd Average Speed Time Time Time Current Dload Upload Total Spent Left Speed 0 0 0 0 0 0 0 0 --:--:-- --:--:-- --:--:-- 0 100 1441k 100 1441k 0 0 5932k 0 --:--:-- --:--:-- --:--:-- 5955k >>> mobroute: Fetching https://distfiles.alpinelinux.org/distfiles/edge/mobroute-0.9.0.tar.gz >>> mobroute: Checking sha512sums... mobroute-0.9.0.tar.gz: OK >>> mobroute: Unpacking /var/cache/distfiles/edge/mobroute-0.9.0.tar.gz... go: downloading git.sr.ht/~mil/mobsql v0.9.0 go: downloading github.com/go-playground/validator/v10 v10.21.0 go: downloading github.com/jmoiron/sqlx v1.4.0 go: downloading github.com/gabriel-vasile/mimetype v1.4.3 go: downloading github.com/leodido/go-urn v1.4.0 go: downloading golang.org/x/crypto v0.19.0 go: downloading golang.org/x/text v0.14.0 go: downloading github.com/go-playground/universal-translator v0.18.1 go: downloading github.com/mattn/go-sqlite3 v1.14.24 go: downloading github.com/go-playground/locales v0.14.1 go: downloading golang.org/x/net v0.21.0 go: downloading gopkg.in/yaml.v3 v3.0.1 ? git.sr.ht/~mil/mobroute [no test files] ? git.sr.ht/~mil/mobroute/api/apirtdatabase [no test files] ? git.sr.ht/~mil/mobroute/api/apirtdatabaseq [no test files] ? git.sr.ht/~mil/mobroute/api/apirtinit [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/calcwalk [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/diagnosticst [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/formatterdiagnostics [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/formattergeojson [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/formatterlegs [no test files] ? git.sr.ht/~mil/mobroute/api/apirtroute/formattermapurl [no test files] === RUN Test_ApiRouteYMLGTFS 2025/01/18 09:00:06 Generated mock for input (map[42:../../testhelper/mockgtfs/gtfs_sample_0.yml]): (gtfs zips: [/tmp/32213031.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_788343549.csv) 2025/01/18 09:00:06 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:06 Loading schema tables 2025/01/18 09:00:06 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:06 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:06 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:06 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:06 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:06 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:06 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:06 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:06 Loading schema tables ok 2025/01/18 09:00:06 Loading schema indexes 2025/01/18 09:00:06 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:06 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:06 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:06 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:06 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:06 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:06 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:06 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:06 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:06 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:06 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:06 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:06 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:06 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:06 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:06 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:06 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:06 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:06 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:06 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:06 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:06 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:06 Loading schema indexes ok 2025/01/18 09:00:06 Loading views ok 2025/01/18 09:00:06 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:06 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:06 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:06 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:06 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:06 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:06 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:06 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:06 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:06 Loading views ok 2025/01/18 09:00:06 Importing table from //tmp/mobroute_test_mobdb_788343549.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:06 Last checksum vs current: / C_0M_d5b20fa59131612612ec4fdb4f9d370f015a22f618db2ed2822508cc2b9e02e9; import will occur 2025/01/18 09:00:06 Execute insert query: 2025/01/18 09:00:06 Insert query complete 2025/01/18 09:00:06 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:06 Imported table from //tmp/mobroute_test_mobdb_788343549.csv to table: _gtfssource_mdbcsv ok --- PASS: Test_ApiRouteYMLGTFS (0.02s) PASS ok git.sr.ht/~mil/mobroute/api/apirtroute_test 0.027s ? git.sr.ht/~mil/mobroute/api/apirtschedule [no test files] ? git.sr.ht/~mil/mobroute/api/apirtstops [no test files] ? git.sr.ht/~mil/mobroute/cli [no test files] ? git.sr.ht/~mil/mobroute/csa [no test files] === RUN Test_CheapestArrivalDestination --- PASS: Test_CheapestArrivalDestination (0.00s) === RUN Test_ExecuteCSAMainLoop 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete 2025/01/18 09:00:06 CSA Main Loop Begin 2025/01/18 09:00:06 CSA Main Loop Complete --- PASS: Test_ExecuteCSAMainLoop (0.00s) === RUN Test_TransferPossibleBetweenConnections --- PASS: Test_TransferPossibleBetweenConnections (0.00s) PASS ok git.sr.ht/~mil/mobroute/csa_test 0.004s ? git.sr.ht/~mil/mobroute/csa_test/csa_testhelper [no test files] ? git.sr.ht/~mil/mobroute/dbquery [no test files] === RUN Test_LoadConnections 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_sample_0.yml]): (gtfs zips: [/tmp/3330550001.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_960158523.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_960158523.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_df71b51d0f027da79c5b613b0c4fe4a906b8135d1d2c78873cf32b8e50d3007d; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_960158523.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/3330550001.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/3330550001.zip to temporary directory: /tmp/mobroute_tempdir3864275711 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c15705f0e743a50086d3c871e24b6165b3b4d723a3f96445f676c4216a2fcd14; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3864275711/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 9 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3864275711/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3864275711/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3864275711/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/3330550001.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136,42:stop_times:C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6,42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899,42:trips:C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc00012a228) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20240304 25200 28800 America/New_York -18000 42]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20240304 25200 28800 America/New_York -18000 42]) to memory ok (len=2) 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_sample_0.yml]): (gtfs zips: [/tmp/3102374981.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_618365643.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_618365643.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_4e74cb65cb18844a8cf8f7a4838171901b4e2e2c4f43592b547aa6d59fd698a7; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_618365643.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/3102374981.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/3102374981.zip to temporary directory: /tmp/mobroute_tempdir2803834772 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c15705f0e743a50086d3c871e24b6165b3b4d723a3f96445f676c4216a2fcd14; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2803834772/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 9 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2803834772/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2803834772/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2803834772/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/3102374981.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136,42:stop_times:C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6,42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899,42:trips:C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc000537598) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20230818 72000 75600 America/New_York -14400 42]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20230818 72000 75600 America/New_York -14400 42]) to memory ok (len=4) 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_sample_0.yml 43:../testhelper/mockgtfs/gtfs_sample_1.yml]): (gtfs zips: [/tmp/2889283560.zip /tmp/477693755.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_931335720.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_931335720.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_97a6985fd165b9b09274e252bd472d2fabd28a067d3093030f41450647f167e0; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_931335720.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42,43],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 2 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 2) 2025/01/18 09:00:07 Loading /tmp/2889283560.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/2889283560.zip to temporary directory: /tmp/mobroute_tempdir1258088598 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c15705f0e743a50086d3c871e24b6165b3b4d723a3f96445f676c4216a2fcd14; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1258088598/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 9 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1258088598/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1258088598/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1258088598/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/2889283560.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Loading GTFS feed 43 (2 of 2) 2025/01/18 09:00:07 Loading /tmp/477693755.zip to DB with GTFS feed: 43 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/477693755.zip to temporary directory: /tmp/mobroute_tempdir2290526764 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_ff0363444c30e50468d902237b474ab438a9e78058f5bc3e72580097a477a123; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2290526764/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 9 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2290526764/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2290526764/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2290526764/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/477693755.zip to DB with GTFS feed: 43 ok 2025/01/18 09:00:07 Loading GTFS feed 43 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 2 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42,43],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 2 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136,42:stop_times:C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6,42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899,42:trips:C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7') 2025/01/18 09:00:07 Computed table _ctconn for feed (43 ) out of date - updating ('' vs '43:routes:C_0M_adc89b7b4e4f8b88e68bf10397af1fc696e623cfec1d5ebd84a57dfac7953136,43:stop_times:C_0M_c720fd568d7d6154f442f16b61c73437ba7452ed091d91c002b4f384d60b36c6,43:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899,43:trips:C_0M_0220e37a7822e751eaa95f847f72fd94eb66c922e5a43f58f2bc059b96efdce7') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (43 ) out of date - updating ('' vs '43:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc0002ff278) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc0002ff288) out of date - updating ('' vs '42:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899,43:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (43 0xc0002ff2a8) out of date - updating ('' vs '43:stops:C_0M_1e4481e4464525fdf1ea0305fca00f2c9d379749fff7d64a0cd7ffa5175af899') 2025/01/18 09:00:07 Running Compute against 2 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds union select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?,?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20240304 18000 32400 America/New_York -18000 America/Chicago -21600 42 43]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds union select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?,?) join _ctconn con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select oid,trip_id,from_stop_sequence,from_stop_parent_uid,from_stop_drutctime,to_stop_sequence,to_stop_parent_uid,to_stop_drutctime from timetable where 1 = 1 ([20240304 18000 32400 America/New_York -18000 America/Chicago -21600 42 43]) to memory ok (len=4) --- PASS: Test_LoadConnections (0.18s) === RUN Test_LoadConnectionsVerbose 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_agency_fmt_nilagencyid.yml]): (gtfs zips: [/tmp/1225385793.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_2718076280.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_2718076280.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_e20bb870f4e264a3d2b9eeac69c0963a871853f858bef14c7d5b04af3cef5802; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_2718076280.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/1225385793.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/1225385793.zip to temporary directory: /tmp/mobroute_tempdir3173977344 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_ba39c5c760c18856a8bb3e6b63e9688c4cf76a4800d54373e7084f0f7e01d7b3; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3173977344/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_d9bce8ae7ee7dfa8ffc2951ca370d0c3a5e3a3b34a234791d52a7ee735613704; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 5 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_192859d996a594c799ed78e3d50de8364a2d585195de939c4e1c218633e55290; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir3173977344/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir3173977344/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3173977344/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/1225385793.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_d9bce8ae7ee7dfa8ffc2951ca370d0c3a5e3a3b34a234791d52a7ee735613704,42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07,42:trips:C_0M_192859d996a594c799ed78e3d50de8364a2d585195de939c4e1c218633e55290') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc000343798) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory ok (len=3) 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_agency_fmt_oneagencyid.yml]): (gtfs zips: [/tmp/3642602951.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_703750131.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_703750131.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_bb4e36bef5ea1da207e84acce1d46e7c2f0f6cafdd75a9c36c4742ee891d9bda; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_703750131.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/3642602951.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/3642602951.zip to temporary directory: /tmp/mobroute_tempdir2339784050 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_c15705f0e743a50086d3c871e24b6165b3b4d723a3f96445f676c4216a2fcd14; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2339784050/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_d9bce8ae7ee7dfa8ffc2951ca370d0c3a5e3a3b34a234791d52a7ee735613704; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 4 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 5 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_192859d996a594c799ed78e3d50de8364a2d585195de939c4e1c218633e55290; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir2339784050/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir2339784050/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2339784050/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/3642602951.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_d9bce8ae7ee7dfa8ffc2951ca370d0c3a5e3a3b34a234791d52a7ee735613704,42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07,42:trips:C_0M_192859d996a594c799ed78e3d50de8364a2d585195de939c4e1c218633e55290') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc000499488) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory ok (len=3) 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_agency_fmt_multiagencyid.yml]): (gtfs zips: [/tmp/1733179471.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_2505328773.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_2505328773.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_a9906877becacfef4c1779249ee515dd7aaafe9c9cddcaff4381924fbc3e2669; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_2505328773.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/1733179471.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/1733179471.zip to temporary directory: /tmp/mobroute_tempdir1312894734 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_1b19c5b299e31d8d1cfefb7e48146986c62c848400fef102c60695b4f0775d32; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 3 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Last checksum vs current: / C_0M_124e46e20a21debc5240cba81ffd1f420ad3546f91373ae55886e911b19b2608; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into calendar ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/calendar.txt to table: calendar ok 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1312894734/calendar_dates.txt 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_f388cfe714ea19d79a0718f2ec6d011ba3747eafdd8040ca160d14b293599e76; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 8 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 5 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_40b68a8b536ba5a4e14df14dd606ca3b047f7521077c9aa948e99b2d8615e2ff; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_d6791ceda8f344e670681056012480211612142eddb7ea00221f228f63f5c4a2; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 2 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1312894734/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1312894734/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1312894734/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/1733179471.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_d6791ceda8f344e670681056012480211612142eddb7ea00221f228f63f5c4a2,42:stop_times:C_0M_f388cfe714ea19d79a0718f2ec6d011ba3747eafdd8040ca160d14b293599e76,42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07,42:trips:C_0M_40b68a8b536ba5a4e14df14dd606ca3b047f7521077c9aa948e99b2d8615e2ff') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc000375158) out of date - updating ('' vs '42:stops:C_0M_0a1e1a76e511685c15e5b6fbd35e233bbdcaba3f388e7381cc9e2bc2e0233b07') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory 2025/01/18 09:00:07 Loaded with inputs as (select ? as yyyymmdddate, ? as seconds_from, ? as seconds_to), tztodelta as (select ? as timezone, ? as seconds), feedidtotzutcdelta as ( -- Note: re distinct, per GTFS spec; if there is >1 agency in agency.txt -- all timezones must be equal; thus 1 feed_id always = 1 timezone -- irregardless of # of agenc(ies) select distinct agency.feed_id, tztodelta.seconds as tzutcdeltasecs from agency join tztodelta on agency.agency_timezone = tztodelta.timezone ), timetable as ( select cts.service_date, -- E.g. normalize from/to stop times in two ways: -- 1) normalize to the input date YYYYMMDD, so if a time departs at 02:00 on monday the following day; -- converted look like 26:00 on the previous day (since all times relative to input YYYYMMDD) -- 2) add the agency's associated timezone UTC delta value so that routing across agencies -- using different timezones functions correctly. All outuput values thus in UTC time -- (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.from_stop_time + tz.tzutcdeltasecs as from_stop_drutctime, (cts.service_date - inputs.yyyymmdddate) * (60 * 60 * 24) + con.to_stop_time + tz.tzutcdeltasecs as to_stop_drutctime, con.oid, con.* from _ctcaltoservice cts join inputs on ( -- E.g. optimization so we don't have to calculate {from,to}_stop_drutctime for *all* -- timetable entries (should handle both tz shifts & next day for schedule logic) cts.service_date between inputs.yyyymmdddate - 1 and inputs.yyyymmdddate + 1 ) and cts.feed_id in (?) join _vconnverbose con on cts.service_id = con.service_id and cts.feed_id = con.feed_id and from_stop_drutctime between seconds_from and seconds_to join feedidtotzutcdelta tz on con.feed_id = tz.feed_id order by from_stop_drutctime asc, con.from_stop_sequence asc ) select * from timetable where 1 = 1 ([20240304 -18000 68400 America/New_York -18000 42]) to memory ok (len=6) --- PASS: Test_LoadConnectionsVerbose (0.16s) === RUN Test_LoadStopWalks 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_simple_stops.yml]): (gtfs zips: [/tmp/1325347616.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_625341634.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:07 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:07 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:07 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:07 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:07 Loading schema tables ok 2025/01/18 09:00:07 Loading schema indexes 2025/01/18 09:00:07 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:07 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:07 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:07 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:07 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:07 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:07 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:07 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:07 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:07 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:07 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:07 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:07 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:07 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:07 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:07 Loading schema indexes ok 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:07 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:07 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:07 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:07 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:07 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:07 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:07 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:07 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:07 Loading views ok 2025/01/18 09:00:07 Importing table from //tmp/mobroute_test_mobdb_625341634.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:07 Last checksum vs current: / C_0M_912dcdc548ceca919a96c578ad213cf72d51ac93b7cd825cd6532f91a7a8df33; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Imported table from //tmp/mobroute_test_mobdb_625341634.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:07 Running Load against 1 feeds 2025/01/18 09:00:07 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:07 Loading /tmp/1325347616.zip to DB with GTFS feed: 42 2025/01/18 09:00:07 Loaded GTFS Archive /tmp/1325347616.zip to temporary directory: /tmp/mobroute_tempdir1753479610 2025/01/18 09:00:07 Loading table: agency 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:07 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into agency ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/agency.txt to table: agency ok 2025/01/18 09:00:07 Loading table: agency complete 2025/01/18 09:00:07 Loading table: calendar 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1753479610/calendar.txt 2025/01/18 09:00:07 Loading table: calendar complete 2025/01/18 09:00:07 Loading table: calendar_dates 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:07 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:07 Loading table: calendar_dates complete 2025/01/18 09:00:07 Loading table: stop_times 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:07 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into stop_times ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/stop_times.txt to table: stop_times ok 2025/01/18 09:00:07 Loading table: stop_times complete 2025/01/18 09:00:07 Loading table: stops 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:07 Last checksum vs current: / C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 10 rows into stops ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/stops.txt to table: stops ok 2025/01/18 09:00:07 Loading table: stops complete 2025/01/18 09:00:07 Loading table: trips 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:07 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into trips ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/trips.txt to table: trips ok 2025/01/18 09:00:07 Loading table: trips complete 2025/01/18 09:00:07 Loading table: routes 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:07 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:07 Execute insert query: 2025/01/18 09:00:07 Insert query complete 2025/01/18 09:00:07 Imported 1 rows into routes ok 2025/01/18 09:00:07 Imported table from /tmp/mobroute_tempdir1753479610/routes.txt to table: routes ok 2025/01/18 09:00:07 Loading table: routes complete 2025/01/18 09:00:07 Loading table: transfers 2025/01/18 09:00:07 Importing table from /tmp/mobroute_tempdir1753479610/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:07 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1753479610/transfers.txt 2025/01/18 09:00:07 Loading table: transfers complete 2025/01/18 09:00:07 Loaded /tmp/1325347616.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:07 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:07 Running Load against 1 feeds ok 2025/01/18 09:00:07 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:07 Running Compute against 1 feeds 2025/01/18 09:00:07 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:07 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:07 Computed table _cttransfersgen for feed (42 0xc0002ffe58) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:07 Running Compute against 1 feeds ok 2025/01/18 09:00:07 Loading with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) order by dist_km asc limit ? ([1.1 0.2 50 42 -1]) to memory 2025/01/18 09:00:07 Loaded with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) order by dist_km asc limit ? ([1.1 0.2 50 42 -1]) to memory ok (len=4) 2025/01/18 09:00:07 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_simple_stops.yml]): (gtfs zips: [/tmp/3396977669.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_1073817720.csv) 2025/01/18 09:00:07 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:07 Loading schema tables 2025/01/18 09:00:07 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_1073817720.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e33346f244e31f1e6b343df040b2f0a57e6d824b81def8070c8c1a69e1e28db1; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_1073817720.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/3396977669.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/3396977669.zip to temporary directory: /tmp/mobroute_tempdir3446175941 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3446175941/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 10 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir3446175941/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir3446175941/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir3446175941/transfers.txt 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/3396977669.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc0005375b8) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) order by dist_km asc limit ? ([1.1 0.2 20 42 -1]) to memory 2025/01/18 09:00:08 Loaded with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) order by dist_km asc limit ? ([1.1 0.2 20 42 -1]) to memory ok (len=4) 2025/01/18 09:00:08 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_simple_stops.yml]): (gtfs zips: [/tmp/1643864927.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_1618020931.csv) 2025/01/18 09:00:08 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:08 Loading schema tables 2025/01/18 09:00:08 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_1618020931.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_8691909d4a834d22d896831daff2ca6d8f24623a30381a0c1f12b103c3848e05; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_1618020931.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/1643864927.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/1643864927.zip to temporary directory: /tmp/mobroute_tempdir1214614377 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1214614377/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 10 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1214614377/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1214614377/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1214614377/transfers.txt 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/1643864927.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc000375938) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) and dist_km is not null order by dist_km asc limit ? ([1.1 0.2 20 42 -1]) to memory 2025/01/18 09:00:08 Loaded with input_coord as (select ? as lat, ? as lon), dists as ( select distinct s.feed_id, vsp.feed_id || '_' || vsp.parent_station as stop_uid, s.stop_name, s.stop_lat, s.stop_lon, 6371.0 * acos( sin(input_coord.lat * pi() / 180.0) * sin(s.stop_lat * pi() / 180.0) + cos(input_coord.lat * pi() / 180.0) * cos(s.stop_lat * pi() / 180.0) * cos((s.stop_lon - input_coord.lon) * pi() / 180.0) ) as dist_km_a from input_coord join stops s on 1 = 1 join _vstopparent vsp on s.feed_id = vsp.feed_id and vsp.parent_station = s.stop_id order by dist_km_a asc ) select stop_uid, stop_name, stop_lat, stop_lon, iif(dist_km_a > ?, null, dist_km_a) as dist_km from dists where feed_id in (?) and (length(?) = 0 or lower(stop_uid || ' ' || stop_name) glob lower('*' || ? || '*')) and dist_km is not null order by dist_km asc limit ? ([1.1 0.2 20 42 -1]) to memory ok (len=1) --- PASS: Test_LoadStopWalks (0.12s) === RUN Test_LoadTransfers 2025/01/18 09:00:08 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_transfers.yml]): (gtfs zips: [/tmp/401346718.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_4276633556.csv) 2025/01/18 09:00:08 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:08 Loading schema tables 2025/01/18 09:00:08 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_4276633556.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_3e25f5e3f20ff05cbb5d6ba3e676c8840a96e9fcb6d9c799e43f1cedbd508ebd; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_4276633556.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/401346718.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/401346718.zip to temporary directory: /tmp/mobroute_tempdir1787335136 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1787335136/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 4 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1787335136/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Last checksum vs current: / C_0M_62f6463902bf0c18eefcc88fd81a21fbf559daca8485920a3653a28636aa83f5; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 2 rows into transfers ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1787335136/transfers.txt to table: transfers ok 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/401346718.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc0002b9698) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([0 3.5 0 0 3.5 0 0 42 42 1000 f]) to memory 2025/01/18 09:00:08 Loaded select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([0 3.5 0 0 3.5 0 0 42 42 1000 f]) to memory ok (len=2) 2025/01/18 09:00:08 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_transfers.yml]): (gtfs zips: [/tmp/1844317643.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_788153177.csv) 2025/01/18 09:00:08 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:08 Loading schema tables 2025/01/18 09:00:08 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_788153177.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_377c92f9986ab458659918a894a9fb426ee64b63d1085a9df77e897c9f1836ed; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_788153177.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/1844317643.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/1844317643.zip to temporary directory: /tmp/mobroute_tempdir1101620145 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1101620145/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 4 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1101620145/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Last checksum vs current: / C_0M_62f6463902bf0c18eefcc88fd81a21fbf559daca8485920a3653a28636aa83f5; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 2 rows into transfers ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1101620145/transfers.txt to table: transfers ok 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/1844317643.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc00012b178) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([3 3.5 3 3 3.5 3 3 42 42 1000 i]) to memory 2025/01/18 09:00:08 Loaded select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([3 3.5 3 3 3.5 3 3 42 42 1000 i]) to memory ok (len=3) 2025/01/18 09:00:08 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_transfers.yml]): (gtfs zips: [/tmp/3812497539.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_2406388872.csv) 2025/01/18 09:00:08 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:08 Loading schema tables 2025/01/18 09:00:08 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_2406388872.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_2ccc649e71dafac02ab6b6d8f6860b6441d0890095c654154c042429ab6b67da; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_2406388872.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/3812497539.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/3812497539.zip to temporary directory: /tmp/mobroute_tempdir644784642 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir644784642/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 4 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir644784642/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Last checksum vs current: / C_0M_62f6463902bf0c18eefcc88fd81a21fbf559daca8485920a3653a28636aa83f5; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 2 rows into transfers ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir644784642/transfers.txt to table: transfers ok 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/3812497539.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc0005372c8) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([3 3.5 3 3 3.5 3 3 42 42 1000 g]) to memory 2025/01/18 09:00:08 Loaded select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (?) ([3 3.5 3 3 3.5 3 3 42 42 1000 g]) to memory ok (len=3) 2025/01/18 09:00:08 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_transfers.yml]): (gtfs zips: [/tmp/1798648497.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_1064092642.csv) 2025/01/18 09:00:08 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:08 Loading schema tables 2025/01/18 09:00:08 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:08 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:08 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:08 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:08 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:08 Loading schema tables ok 2025/01/18 09:00:08 Loading schema indexes 2025/01/18 09:00:08 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:08 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:08 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:08 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:08 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:08 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:08 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:08 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:08 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:08 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:08 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:08 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:08 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:08 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:08 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:08 Loading schema indexes ok 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:08 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:08 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:08 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:08 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:08 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:08 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:08 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:08 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:08 Loading views ok 2025/01/18 09:00:08 Importing table from //tmp/mobroute_test_mobdb_1064092642.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:08 Last checksum vs current: / C_0M_fa8a910fd423fe7a0b3624a6b8df1fb50f11177a86d85af7670e7aa480a96584; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Imported table from //tmp/mobroute_test_mobdb_1064092642.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:08 Running Load against 1 feeds 2025/01/18 09:00:08 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:08 Loading /tmp/1798648497.zip to DB with GTFS feed: 42 2025/01/18 09:00:08 Loaded GTFS Archive /tmp/1798648497.zip to temporary directory: /tmp/mobroute_tempdir1444633677 2025/01/18 09:00:08 Loading table: agency 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:08 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into agency ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/agency.txt to table: agency ok 2025/01/18 09:00:08 Loading table: agency complete 2025/01/18 09:00:08 Loading table: calendar 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:08 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1444633677/calendar.txt 2025/01/18 09:00:08 Loading table: calendar complete 2025/01/18 09:00:08 Loading table: calendar_dates 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:08 Loading table: calendar_dates complete 2025/01/18 09:00:08 Loading table: stop_times 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:08 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into stop_times ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/stop_times.txt to table: stop_times ok 2025/01/18 09:00:08 Loading table: stop_times complete 2025/01/18 09:00:08 Loading table: stops 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:08 Last checksum vs current: / C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 4 rows into stops ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/stops.txt to table: stops ok 2025/01/18 09:00:08 Loading table: stops complete 2025/01/18 09:00:08 Loading table: trips 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:08 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into trips ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/trips.txt to table: trips ok 2025/01/18 09:00:08 Loading table: trips complete 2025/01/18 09:00:08 Loading table: routes 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:08 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 1 rows into routes ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/routes.txt to table: routes ok 2025/01/18 09:00:08 Loading table: routes complete 2025/01/18 09:00:08 Loading table: transfers 2025/01/18 09:00:08 Importing table from /tmp/mobroute_tempdir1444633677/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:08 Last checksum vs current: / C_0M_62f6463902bf0c18eefcc88fd81a21fbf559daca8485920a3653a28636aa83f5; import will occur 2025/01/18 09:00:08 Execute insert query: 2025/01/18 09:00:08 Insert query complete 2025/01/18 09:00:08 Imported 2 rows into transfers ok 2025/01/18 09:00:08 Imported table from /tmp/mobroute_tempdir1444633677/transfers.txt to table: transfers ok 2025/01/18 09:00:08 Loading table: transfers complete 2025/01/18 09:00:08 Loaded /tmp/1798648497.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:08 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:08 Running Load against 1 feeds ok 2025/01/18 09:00:08 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:08 Running Compute against 1 feeds 2025/01/18 09:00:08 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:08 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Computed table _cttransfersgen for feed (42 0xc000375788) out of date - updating ('' vs '42:stops:C_0M_e49bcb4d76fb2c80913af3c8407007f34b72c84c7045982cdafa519098886897') 2025/01/18 09:00:08 Running Compute against 1 feeds ok 2025/01/18 09:00:08 Loading select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (? , ?) ([3 3.5 3 3 3.5 3 3 42 42 1000 f g]) to memory 2025/01/18 09:00:08 Loaded select * from ( -- Implicit transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, to_feed_id, 'i' as transfer_category, ? as transfer_seconds from _vtransfersimplicit union all -- Generated transfers select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'g' as transfer_category, -- Uses dist_km to determine seconds transfer cost; round up to min_seconds max(coalesce(cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _cttransfersgen union all -- Feed transfers (transfers.txt) select from_stop_parent_uid, from_stop_parent_id, from_stop_id, feed_id as from_feed_id, to_stop_parent_uid, to_stop_parent_id, to_stop_id, feed_id_pair as to_feed_id, 'f' as transfer_category, -- Uses min_transfer_time, else use dist_km; round up to min_seconds max(coalesce(min_transfer_time, cast(dist_km / ? * 60 * 60 as uint), ?), ?) as transfer_seconds from _vtransferstbl ) t where ((from_feed_id = ? and to_feed_id = ?)) and transfer_seconds < ? and transfer_category in (? , ?) ([3 3.5 3 3 3.5 3 3 42 42 1000 f g]) to memory ok (len=5) --- PASS: Test_LoadTransfers (0.17s) PASS ok git.sr.ht/~mil/mobroute/dbquery_test 0.650s ? git.sr.ht/~mil/mobroute/dbschemaextra [no test files] ? git.sr.ht/~mil/mobroute/dbstubquery [no test files] === RUN Test_LoadCalToService 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_cal_only.yml]): (gtfs zips: [/tmp/2856515989.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_765821216.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_765821216.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_2ce1ed7df49a9444a49108cdd34ab8fa8c600842b047b789bba8689905a5f5a7; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_765821216.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/2856515989.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/2856515989.zip to temporary directory: /tmp/mobroute_tempdir384404509 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Last checksum vs current: / C_0M_e3b90f0aa591f682039ce6ac7a9f4e8f46025c2346ee8478c06a04300d59ed12; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 2 rows into calendar ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/calendar.txt to table: calendar ok 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir384404509/calendar_dates.txt 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir384404509/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir384404509/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir384404509/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/2856515989.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc00048b9e8) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230620 20230621]) to memory 2025/01/18 09:00:09 Loaded select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230620 20230621]) to memory ok (len=4) 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_cal_only.yml]): (gtfs zips: [/tmp/859867587.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_4114444157.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_4114444157.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_d457e4cb3c1dcef7311194a3c1f15abd4d78c06d14e66409873fba1ea6367385; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_4114444157.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/859867587.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/859867587.zip to temporary directory: /tmp/mobroute_tempdir2928988499 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Last checksum vs current: / C_0M_e3b90f0aa591f682039ce6ac7a9f4e8f46025c2346ee8478c06a04300d59ed12; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 2 rows into calendar ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/calendar.txt to table: calendar ok 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2928988499/calendar_dates.txt 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir2928988499/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir2928988499/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir2928988499/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/859867587.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc00069a858) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20270619 20270622]) to memory 2025/01/18 09:00:09 Loaded select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20270619 20270622]) to memory ok (len=0) 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_caldates_only.yml]): (gtfs zips: [/tmp/3695984416.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_3638791168.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_3638791168.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_efd030d72f2b8541a4f9f67f8411ef5101aedd65dd26f2f1c877becb8e461cf4; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_3638791168.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/3695984416.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/3695984416.zip to temporary directory: /tmp/mobroute_tempdir1413197334 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1413197334/calendar.txt 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Last checksum vs current: / C_0M_c9a596973ac871ddba3e27cef7cc8ef2d3481b1fd98a210e6f398bd2ce95a687; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 6 rows into calendar_dates ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1413197334/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1413197334/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1413197334/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/3695984416.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc000015ea8) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230302 20230303]) to memory 2025/01/18 09:00:09 Loaded select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230302 20230303]) to memory ok (len=3) 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_caldates_only.yml]): (gtfs zips: [/tmp/4001072537.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_2010302432.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_2010302432.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_114bd6e646bbf05201a3954ac88e396c768eeca72e03c1dd05e4a24222b68668; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_2010302432.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/4001072537.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/4001072537.zip to temporary directory: /tmp/mobroute_tempdir1334855556 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1334855556/calendar.txt 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Last checksum vs current: / C_0M_c9a596973ac871ddba3e27cef7cc8ef2d3481b1fd98a210e6f398bd2ce95a687; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 6 rows into calendar_dates ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1334855556/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1334855556/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1334855556/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/4001072537.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc0002f8ef8) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230402 20230703]) to memory 2025/01/18 09:00:09 Loaded select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230402 20230703]) to memory ok (len=0) 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_cal_and_caldates.yml]): (gtfs zips: [/tmp/233895853.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_304225243.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_304225243.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_e3a92c6239a4f450a8f3cac86e6f9829e0e1e48f836fb14d8d73f602f193446c; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_304225243.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/233895853.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/233895853.zip to temporary directory: /tmp/mobroute_tempdir1151263072 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Last checksum vs current: / C_0M_1a479c2cc8fe96fa8aacf573305f61c13d80b613e0c9ca8c3b964d91ece992ca; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 2 rows into calendar ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/calendar.txt to table: calendar ok 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Last checksum vs current: / C_0M_674e838dce9a30acbf7bc93af3c4c8f4856ba5f0b7c966777d38b29df07f8800; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 4 rows into calendar_dates ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir1151263072/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir1151263072/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir1151263072/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/233895853.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc000366ed8) out of date - updating ('' vs '42:stops:C_0M_0e74a5076f0274b109142fc425c74cff47bef02800122d1f65189c2f2ac9ddbb') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230906 20230910]) to memory 2025/01/18 09:00:09 Loaded select feed_id, service_date, service_id from _ctcaltoservice where feed_id = ? and service_date between ? and ? ([42 20230906 20230910]) to memory ok (len=7) --- PASS: Test_LoadCalToService (0.22s) === RUN Test_LoadStopToParent 2025/01/18 09:00:09 Generated mock for input (map[42:../testhelper/mockgtfs/gtfs_simple_stops.yml]): (gtfs zips: [/tmp/2398981186.zip]) (mobdb csv: /tmp/mobroute_test_mobdb_807413409.csv) 2025/01/18 09:00:09 SQLite system version (3.46.1); comparing to required version: 3.28.0 2025/01/18 09:00:09 Loading schema tables 2025/01/18 09:00:09 Execute statement: create table if not exists _mobsqltrack ('feed_id' int not null,'feed_id_pair' int,'tbl' text not null,'checksum' text not null,'n_rows' int not null,'timestamp' int not null,unique(feed_id,feed_id_pair,tbl)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_mdbcsv ('feed_id' int not null check(feed_id = -1),'data_type' text not null,'location.bounding_box.minimum_latitude' real,'location.bounding_box.minimum_longitude' real,'location.bounding_box.maximum_latitude' real,'location.bounding_box.maximum_longitude' real,'location.country_code' text,'location.subdivision_name' text,'location.municipality' text,'urls.direct_download' text,'urls.latest' text,'urls.license' text,'mdb_source_id' int not null check(mdb_source_id >= 0),'name' text,'status' text,'provider' text not null,unique(mdb_source_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists _gtfssource_custom ('customgtfs_feed_id' int not null check(customgtfs_feed_id < -1),'gtfs_uri' text not null,unique(customgtfs_feed_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists agency ('feed_id' int not null,'agency_id' text,'agency_name' text not null,'agency_url' text not null,'agency_timezone' text not null,unique(feed_id,agency_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar ('feed_id' int not null,'service_id' text not null,'monday' int not null check(monday in (0,1)),'tuesday' int not null check(tuesday in (0,1)),'wednesday' int not null check(wednesday in (0,1)),'thursday' int not null check(thursday in (0,1)),'friday' int not null check(friday in (0,1)),'saturday' int not null check(saturday in (0,1)),'sunday' int not null check(sunday in (0,1)),'start_date' int not null,'end_date' int not null,unique(feed_id,service_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists calendar_dates ('feed_id' int not null,'service_id' text not null,'date' int not null,'exception_type' int not null check(exception_type in (1,2))) 2025/01/18 09:00:09 Execute statement: create table if not exists stop_times ('feed_id' int not null,'trip_id' text not null,'arrival_time' int,'departure_time' int,'stop_id' text not null,'stop_sequence' int not null,'stop_headsign' text,'pickup_type' int,'drop_off_type' int,'continuous_drop_off' text,'timepoint' int check(timepoint in (0,1)),unique(feed_id,trip_id,stop_sequence)) 2025/01/18 09:00:09 Execute statement: create table if not exists stops ('feed_id' int not null,'stop_id' text not null,'stop_code' text,'stop_name' text check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_name is not null) or (location_type = 3 or location_type = 4) ),'stop_desc' text,'stop_lat' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lat is not null) or (location_type = 3 or location_type = 4) ),'stop_lon' real check( ((location_type is null or location_type = 0 or location_type = 1 or location_type = 2) and stop_lon is not null) or (location_type = 3 or location_type = 4) ),'zone_id' text,'stop_url' text,'location_type' int check(location_type in (0,1,2,3,4)),'parent_station' text,'stop_timezone' text,'wheelchair_boarding' int check(wheelchair_boarding in (0,1,2)),'level_id' text,'platform_code' text,unique(feed_id,stop_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists trips ('feed_id' int not null,'route_id' text not null,'service_id' text not null,'trip_id' text not null,'trip_headsign' text,'trip_short_name' text,'direction_id' int check(direction_id in (0,1)),'block_id' text,'shape_id' text,'wheelchair_accessible' text check(wheelchair_accessible in (0,1,2)),'bikes_allowed' int check(bikes_allowed in (0,1,2)),unique(feed_id,trip_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists routes ('feed_id' int not null,'route_id' text not null,'agency_id' text,'route_short_name' text check(route_long_name is not null or route_short_name is not null),'route_long_name' text,'route_desc' text,'route_type' int,'route_url' text,'route_color' text,'route_text_color' text,'route_sort_order' text,'continuous_pickup' int check(continuous_pickup in (0,1,2,3)),'continuous_drop_off' int check(continuous_drop_off in (0,1,2,3)),unique(feed_id,route_id)) 2025/01/18 09:00:09 Execute statement: create table if not exists transfers ('feed_id' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'transfer_type' int,'min_transfer_time' int) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctconn ('feed_id' int not null,'trip_id' text not null,'service_id' text not null,'from_stop_id' text not null,'from_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'from_stop_time' int not null,'from_stop_sequence' int not null,'to_stop_id' text not null,'to_stop_parent_id' text not null,'to_stop_parent_uid' text not null,'to_stop_time' int not null,'to_stop_sequence' int not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _ctcaltoservice ('feed_id' int not null,'service_date' int not null,'service_id' text not null) 2025/01/18 09:00:09 Execute statement: create table if not exists _cttransfersgen ('feed_id' int not null,'feed_id_pair' int not null,'from_stop_id' text not null,'to_stop_id' text not null,'from_stop_parent_id' text not null,'to_stop_parent_id' text not null,'from_stop_parent_uid' text not null,'to_stop_parent_uid' text not null,'dist_km' real) 2025/01/18 09:00:09 Loading schema tables ok 2025/01/18 09:00:09 Loading schema indexes 2025/01/18 09:00:09 Create index idx_agency1_agency_timezone on agency as [agency_timezone] 2025/01/18 09:00:09 Created index idx_agency1_agency_timezone ok 2025/01/18 09:00:09 Create index idx_stop_times1_trip_id on stop_times as [trip_id] 2025/01/18 09:00:09 Created index idx_stop_times1_trip_id ok 2025/01/18 09:00:09 Create index idx_stops2_feed_id_stop_id on stops as [feed_id stop_id] 2025/01/18 09:00:09 Created index idx_stops2_feed_id_stop_id ok 2025/01/18 09:00:09 Create index idx_stops2_stop_lat_stop_lon on stops as [stop_lat stop_lon] 2025/01/18 09:00:09 Created index idx_stops2_stop_lat_stop_lon ok 2025/01/18 09:00:09 Create index idx_stops3_feed_id_parent_station_location_type on stops as [feed_id parent_station location_type] 2025/01/18 09:00:09 Created index idx_stops3_feed_id_parent_station_location_type ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_from_stop_id on transfers as [feed_id from_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_from_stop_id ok 2025/01/18 09:00:09 Create index idx_transfers2_feed_id_to_stop_id on transfers as [feed_id to_stop_id] 2025/01/18 09:00:09 Created index idx_transfers2_feed_id_to_stop_id ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_service_id_from_stop_time on _ctconn as [feed_id service_id from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_service_id_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time on _ctconn as [feed_id from_stop_parent_uid from_stop_time] 2025/01/18 09:00:09 Created index idx__ctconn3_feed_id_from_stop_parent_uid_from_stop_time ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice3_feed_id_service_id_service_date on _ctcaltoservice as [feed_id service_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice3_feed_id_service_id_service_date ok 2025/01/18 09:00:09 Create index idx__ctcaltoservice2_feed_id_service_date on _ctcaltoservice as [feed_id service_date] 2025/01/18 09:00:09 Created index idx__ctcaltoservice2_feed_id_service_date ok 2025/01/18 09:00:09 Loading schema indexes ok 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Loaded view _vfeedsminmaxdates (bytes=251) 2025/01/18 09:00:09 Loaded view _vfeedsmetadata (bytes=3785) 2025/01/18 09:00:09 Loaded view _vstopparent (bytes=2600) 2025/01/18 09:00:09 Loaded view _vconn (bytes=1225) 2025/01/18 09:00:09 Loaded view _vconnverbose (bytes=1173) 2025/01/18 09:00:09 Loaded view _vcaltoservice (bytes=3110) 2025/01/18 09:00:09 Loaded view _vtransferstbl (bytes=957) 2025/01/18 09:00:09 Loaded view _vtransfersgen (bytes=1559) 2025/01/18 09:00:09 Loaded view _vtransfersimplicit (bytes=395) 2025/01/18 09:00:09 Loading views ok 2025/01/18 09:00:09 Importing table from //tmp/mobroute_test_mobdb_807413409.csv (0.00MB) to table: _gtfssource_mdbcsv 2025/01/18 09:00:09 Last checksum vs current: / C_0M_3d9bc3b3b9bd48496f7041d81bf89370631d03ff7eb7399914b6b375484b4640; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Imported table from //tmp/mobroute_test_mobdb_807413409.csv to table: _gtfssource_mdbcsv ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"loadmdbgtfs"} 2025/01/18 09:00:09 Running Load against 1 feeds 2025/01/18 09:00:09 Loading GTFS feed 42 (1 of 1) 2025/01/18 09:00:09 Loading /tmp/2398981186.zip to DB with GTFS feed: 42 2025/01/18 09:00:09 Loaded GTFS Archive /tmp/2398981186.zip to temporary directory: /tmp/mobroute_tempdir162840300 2025/01/18 09:00:09 Loading table: agency 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/agency.txt (0.00MB) to table: agency 2025/01/18 09:00:09 Last checksum vs current: / C_0M_ec69cc35698113d39b116d06df83c168ff34eec1dd5daa90136c2ccdddd57966; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into agency ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/agency.txt to table: agency ok 2025/01/18 09:00:09 Loading table: agency complete 2025/01/18 09:00:09 Loading table: calendar 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/calendar.txt (0.00MB) to table: calendar 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir162840300/calendar.txt 2025/01/18 09:00:09 Loading table: calendar complete 2025/01/18 09:00:09 Loading table: calendar_dates 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/calendar_dates.txt (0.00MB) to table: calendar_dates 2025/01/18 09:00:09 Last checksum vs current: / C_0M_e37e371e5f8c7c355413d55fe59c9054de3dbf0d759f0bcd6ef7968b46cde54e; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into calendar_dates ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/calendar_dates.txt to table: calendar_dates ok 2025/01/18 09:00:09 Loading table: calendar_dates complete 2025/01/18 09:00:09 Loading table: stop_times 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/stop_times.txt (0.00MB) to table: stop_times 2025/01/18 09:00:09 Last checksum vs current: / C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into stop_times ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/stop_times.txt to table: stop_times ok 2025/01/18 09:00:09 Loading table: stop_times complete 2025/01/18 09:00:09 Loading table: stops 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/stops.txt (0.00MB) to table: stops 2025/01/18 09:00:09 Last checksum vs current: / C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 10 rows into stops ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/stops.txt to table: stops ok 2025/01/18 09:00:09 Loading table: stops complete 2025/01/18 09:00:09 Loading table: trips 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/trips.txt (0.00MB) to table: trips 2025/01/18 09:00:09 Last checksum vs current: / C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into trips ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/trips.txt to table: trips ok 2025/01/18 09:00:09 Loading table: trips complete 2025/01/18 09:00:09 Loading table: routes 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/routes.txt (0.00MB) to table: routes 2025/01/18 09:00:09 Last checksum vs current: / C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8; import will occur 2025/01/18 09:00:09 Execute insert query: 2025/01/18 09:00:09 Insert query complete 2025/01/18 09:00:09 Imported 1 rows into routes ok 2025/01/18 09:00:09 Imported table from /tmp/mobroute_tempdir162840300/routes.txt to table: routes ok 2025/01/18 09:00:09 Loading table: routes complete 2025/01/18 09:00:09 Loading table: transfers 2025/01/18 09:00:09 Importing table from /tmp/mobroute_tempdir162840300/transfers.txt (0.00MB) to table: transfers 2025/01/18 09:00:09 Skipped import for non-existant non-required file: /tmp/mobroute_tempdir162840300/transfers.txt 2025/01/18 09:00:09 Loading table: transfers complete 2025/01/18 09:00:09 Loaded /tmp/2398981186.zip to DB with GTFS feed: 42 ok 2025/01/18 09:00:09 Loading GTFS feed 42 ok; used cache for URL download (true) 2025/01/18 09:00:09 Running Load against 1 feeds ok 2025/01/18 09:00:09 Running RTDatabase against input: {"feed_ids":[42],"op":"compute"} 2025/01/18 09:00:09 Running Compute against 1 feeds 2025/01/18 09:00:09 Computed table _ctconn for feed (42 ) out of date - updating ('' vs '42:routes:C_0M_a6031af6418607a6e5f51c20eaa22f422664f8d5254c59438ab18ce7e1e97cf8,42:stop_times:C_0M_34d5ab6ee7cbb3e04fd82bd1dca86e4daecfa570a11b128209c8e5c102662d0a,42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366,42:trips:C_0M_0391ceb043162a440ba78564cae799b0c9b0004ac42d27290246145bfa780435') 2025/01/18 09:00:09 Computed table _ctcaltoservice for feed (42 ) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:09 Computed table _cttransfersgen for feed (42 0xc00048be98) out of date - updating ('' vs '42:stops:C_0M_658a3f90ef5c5b6b531059c770014493d5c29ff969ad1e41a9df10615e479366') 2025/01/18 09:00:09 Running Compute against 1 feeds ok 2025/01/18 09:00:09 Loading select feed_id, stop_id, parent_station from _vstopparent where feed_id = ? ([42]) to memory 2025/01/18 09:00:09 Loaded select feed_id, stop_id, parent_station from _vstopparent where feed_id = ? ([42]) to memory ok (len=10) --- PASS: Test_LoadStopToParent (0.02s) PASS ok git.sr.ht/~mil/mobroute/dbstubquery_test 0.261s ? git.sr.ht/~mil/mobroute/dbt [no test files] ? git.sr.ht/~mil/mobroute/examples/load_customgtfs [no test files] ? git.sr.ht/~mil/mobroute/examples/load_mdbgtfs [no test files] ? git.sr.ht/~mil/mobroute/examples/route [no test files] ? git.sr.ht/~mil/mobroute/examples/schedule [no test files] ? git.sr.ht/~mil/mobroute/examples/stops [no test files] ? git.sr.ht/~mil/mobroute/examples/update_mdbgtfs [no test files] ? git.sr.ht/~mil/mobroute/testhelper [no test files] ? git.sr.ht/~mil/mobroute/testhelper/dbquerytesthelper [no test files] ? git.sr.ht/~mil/mobroute/util/utilcache [no test files] ? git.sr.ht/~mil/mobroute/util/utilfuncs [no test files] === RUN Test_DistHaversine --- PASS: Test_DistHaversine (0.00s) === RUN Test_TimezoneToUTCDeltaSecs --- PASS: Test_TimezoneToUTCDeltaSecs (0.00s) PASS ok git.sr.ht/~mil/mobroute/util/utilfuncs_test 0.005s ? git.sr.ht/~mil/mobroute/util/utillog [no test files] >>> mobroute: Entering fakeroot... >>> mobroute-doc*: Running split function doc... 'usr/share/doc' -> '/home/buildozer/aports/testing/mobroute/pkg/mobroute-doc/usr/share/doc' >>> mobroute-doc*: Preparing subpackage mobroute-doc... >>> mobroute-doc*: Running postcheck for mobroute-doc >>> mobroute*: Running postcheck for mobroute >>> mobroute*: Preparing package mobroute... >>> mobroute*: Stripping binaries >>> mobroute-doc*: Scanning shared objects >>> mobroute*: Scanning shared objects >>> mobroute-doc*: Tracing dependencies... >>> mobroute-doc*: Package size: 2.0 MB >>> mobroute-doc*: Compressing data... >>> mobroute-doc*: Create checksum... >>> mobroute-doc*: Create mobroute-doc-0.9.0-r1.apk >>> mobroute*: Tracing dependencies... tzdata so:libc.musl-x86_64.so.1 >>> mobroute*: Package size: 11.4 MB >>> mobroute*: Compressing data... >>> mobroute*: Create checksum... >>> mobroute*: Create mobroute-0.9.0-r1.apk >>> mobroute: Build complete at Sat, 18 Jan 2025 09:00:10 +0000 elapsed time 0h 1m 27s >>> mobroute: Cleaning up srcdir >>> mobroute: Cleaning up pkgdir >>> mobroute: Uninstalling dependencies... (1/6) Purging .makedepends-mobroute (20250118.085845) (2/6) Purging tzdata (2024b-r1) (3/6) Purging go (1.23.5-r0) (4/6) Purging sqlite-dev (3.48.0-r0) (5/6) Purging sqlite (3.48.0-r0) (6/6) Purging sqlite-libs (3.48.0-r0) Executing busybox-1.37.0-r13.trigger OK: 399 MiB in 106 packages >>> mobroute: Updating the testing/x86_64 repository index... >>> mobroute: Signing the index...