tests/testthat/test-assign_mode.R

tester <- function(mode = "WALK", mode_egress = "WALK") {
  assign_mode(mode, mode_egress)
}

test_that("expects correct modes", {
  expect_error(tester(character()))
  expect_error(tester("oie"))
  expect_error(tester(NA))
  expect_error(tester(mode_egress = c("WALK", "CAR"), style = "ttm"))
  expect_error(tester(mode_egress = "CAR_PARK"))
})

test_that("raises error when receives either CAR_PARK or BICYCLE_RENT", {
  expect_error(tester("CAR_PARK"))
  expect_error(tester("BICYCLE_RENT"))
})

test_that("raises errors when it cannot disambiguate direct modes", {
  expect_error(tester(c("CAR", "WALK")))
  expect_error(tester(c("CAR", "WALK", "TRANSIT")))
})

test_that("mode_egress is ignored when direct modes are passed to mode", {
  expect_identical(tester("WALK", "WALK"), tester("WALK", "BICYCLE"))
  expect_identical(tester("CAR", "WALK"), tester("CAR", "BICYCLE"))
  expect_identical(
    tester("BICYCLE", "WALK"),
    tester("BICYCLE", "CAR")
  )

  expect_identical(
    tester("CAR", "WALK"),
    list(
      direct_modes = "CAR",
      transit_mode = "",
      access_mode = "CAR",
      egress_mode = ""
    )
  )
})

test_that("walk is set to access_mode when not listed in mode", {
  expect_identical(tester(c("BUS", "WALK"), "WALK"), tester("BUS", "WALK"))

  expect_identical(
    tester("BUS", "WALK"),
    list(
      direct_modes = "WALK",
      transit_mode = "BUS",
      access_mode = "WALK",
      egress_mode = "WALK"
    )
  )

  expect_identical(
    tester(c("BUS", "CAR"), "WALK"),
    list(
      direct_modes = "CAR",
      transit_mode = "BUS",
      access_mode = "CAR",
      egress_mode = "WALK"
    )
  )
})

test_that("all pt modes are passed to transit_modes when TRANSIT is present", {
  tr_modes <- c(
    "TRANSIT",
    "TRAM",
    "SUBWAY",
    "RAIL",
    "BUS",
    "FERRY",
    "CABLE_CAR",
    "GONDOLA",
    "FUNICULAR"
  )

  expect_identical(
    tester(c("TRANSIT", "WALK"), "WALK"),
    list(
      direct_modes = "WALK",
      transit_mode = paste0(tr_modes, collapse = ";"),
      access_mode = "WALK",
      egress_mode = "WALK"
    )
  )
})

Try the r5r package in your browser

Any scripts or data that you put into this service are public.

r5r documentation built on Aug. 8, 2023, 9:07 a.m.