tests/testthat/test-calc_traveltime.R

test_that("traveltime works", {
  x <- read_sf(
    system.file("extdata", "sierra_de_neiba_478140.gpkg",
      package = "mapme.biodiversity"
    )
  )
  .clear_resources()
  outdir <- file.path(tempdir(), "mapme.data")
  .copy_resource_dir(outdir)
  mapme_options(outdir = outdir, verbose = FALSE)
  get_resources(x, get_nelson_et_al(ranges = "100k_200k"))
  nelson_et_al <- prep_resources(x)[["nelson_et_al"]]

  ctt <- calc_traveltime()
  expect_true(is.null(ctt(x, NULL)))
  result <- ctt(x, nelson_et_al)
  ctt <- calc_traveltime(stats = c("mean", "median", "sd"))
  result_multi_stat <- ctt(x, nelson_et_al)
  ctt <- calc_traveltime(engine = "zonal")
  result_zonal <- ctt(x, nelson_et_al)
  ctt <- calc_traveltime(engine = "extract")
  result_extract <- ctt(x, nelson_et_al)
  ctt <- calc_traveltime(engine = "exactextract")
  result_exact <- ctt(x, nelson_et_al)

  expect_silent(.check_single_asset(result))
  expect_silent(.check_single_asset(result_multi_stat))
  expect_silent(.check_single_asset(result_zonal))
  expect_silent(.check_single_asset(result_extract))
  expect_silent(.check_single_asset(result_exact))

  vars <- c(
    "100k_200k_traveltime_mean", "100k_200k_traveltime_median",
    "100k_200k_traveltime_sd"
  )
  expect_equal(unique(result_multi_stat$variable)[1:3], vars)
  expect_equal(result_zonal$value, result_zonal$value, tolerance = 1e-4)
  expect_snapshot(result_exact$value)
})
mapme-initiative/mapme.biodiversity documentation built on April 5, 2025, 12:47 p.m.