inst/tinytest/test_integration.R

source("setup.R")

# enable / disable ----

suppressMessages(untrace(utils::install.packages))
expect_false(inherits(utils::install.packages, "functionWithTrace"))

suppressWarnings(expect_message(enable()))
expect_true(inherits(utils::install.packages, "functionWithTrace"))
expect_equal(getOption("pkgType"), "both")

tracer <- paste(body(utils::install.packages), collapse="")
expect_true(sum(grepl("bspm", tracer, fixed=TRUE)) > 0)

expect_message(disable())
expect_false(inherits(utils::install.packages, "functionWithTrace"))
expect_equal(getOption("pkgType"), "source")

# shim ----

test_shim <- function(pkgs, repos = "https://cran.r-project.org",
                      contriburl = contrib.url(repos, type), method,
                      dependencies = NA, type = getOption("pkgType"), ...) {
  eval(body(bspm:::shim))
  list(pkgs=pkgs, type=type)
}

expect_error(test_shim(), "no packages")

## no return
mock_install <- function(msg) function(...) { warning(msg); character(0) }
mock("install_both", mock_install("both"), "bspm")
mock("install_sys",  mock_install("sys"),  "bspm")
mock("install_fast", mock_install("fast"), "bspm")

expect_silent(res <- test_shim("pkg", repos=NULL, type="both"))
expect_equal(res, list(pkgs="pkg", type="source"))
expect_silent(res <- test_shim("pkg", type="source"))
expect_equal(res, list(pkgs="pkg", type="source"))

expect_warning(res <- test_shim("pkg", type="both"), "both")
expect_equal(res, list(pkgs=character(0), type="source"))
expect_warning(res <- test_shim("pkg", type="binary"), "sys")
expect_equal(res, list(pkgs=character(0), type="source"))
expect_warning(res <- test_shim("pkg", type="binary-source"), "fast")
expect_equal(res, list(pkgs=character(0), type="source"))

options(bspm.version.check=FALSE)
expect_warning(res <- test_shim("pkg", type="both"), "fast")
expect_equal(res, list(pkgs=character(0), type="source"))
options(bspm.version.check=NULL)

unmock_all()

## return
mock_install <- function(pkgs, contriburl, ...) {
  expect_inherits(contriburl, "character")
  "notavail"
}
mock("install_both", mock_install, "bspm")
mock("install_sys",  function(...) "notavail", "bspm")
mock("install_fast", mock_install, "bspm")

res <- test_shim("pkg", type="both")
expect_equal(res, list(pkgs="notavail", type="source"))
res <- test_shim("pkg", type="binary")
expect_equal(res, list(pkgs="notavail", type="binary"))
res <- test_shim("pkg", type="binary-source")
expect_equal(res, list(pkgs="notavail", type="source"))

unmock_all()

# install functions ----

pkgs_sys <- c("BH", "Rcpp", "another")
db <- readRDS("db.rds")

mock("available.packages", function(...) db, "utils")
mock("installed.packages", pkg="utils", function(...)
  matrix(1, dimnames=list(c("codetools"), NULL)))
mock("install_sys", function(pkgs) setdiff(pkgs, pkgs_sys), "bspm")
mock("available_sys", pkg="bspm", function() matrix(
  c(pkgs_sys, "1.81.0.0", "1.0.10", "1"), ncol=2,
  dimnames=list(tolower(pkgs_sys), c("Package", "Version"))
))

pkgs <- c("another", "simmer", "rticles")
deps <- c(unname(unlist(tools::package_dependencies(pkgs, recursive=TRUE))), pkgs)
deps <- setdiff(deps, bspm:::available_sys()[, "Package"])
deps <- setdiff(deps, rownames(utils::installed.packages()))

expect_equal(bspm:::install_both(pkgs, dependencies=NA), deps)
expect_equal(bspm:::install_fast(pkgs, dependencies=NA), c("simmer", "rticles"))

unmock_all()

source("teardown.R")

Try the bspm package in your browser

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

bspm documentation built on May 29, 2024, 10:36 a.m.