tests/testthat/helper-skip.R

skip_if_error <- function(expr) {
  tryCatch(
    force(expr),
    error = function(e) {
      skip(e$message)
    }
  )
}

skip_if_remote_src <- function(src = my_test_src()) {
  if (is_db(src)) skip("works only locally")
}

skip_if_src <- function(...) {
  if (my_test_src_name %in% c(...)) {
    skip(glue::glue("does not work on {commas(tick(c(...)))}"))
  }
}

skip_if_src_not <- function(...) {
  if (!(my_test_src_name %in% c(...))) {
    skip(glue::glue("only works on {commas(tick(c(...)))}"))
  }
}

skip_if_schema_supported <- function() {
  not_ok_dbs <- schema_supported_dbs()[["test_shortcut"]]
  skip_if_src(not_ok_dbs)
}
skip_if_schema_not_supported <- function() {
  not_ok_dbs <- schema_supported_dbs()[["test_shortcut"]]
  skip_if_src_not(not_ok_dbs)
}

skip_if_ide <- function() {
  if (!isTRUE(as.logical(Sys.getenv("CI")))) {
    skip("Slow test. To run, set CI=true")
  }
}

skip_if_offline <- function() {
  if (Sys.getenv("DM_OFFLINE") != "") {
    skip("DM_OFFLINE environment variable set")
  }
  testthat::skip_if_offline()
}

suppress_mssql_message <- function(code) {
  if (my_test_src_name == "mssql") {
    suppressMessages(code)
  } else {
    code
  }
}

suppress_mssql_warning <- function(code) {
  if (my_test_src_name == "mssql") {
    suppressWarnings(code)
  } else {
    code
  }
}

Try the dm package in your browser

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

dm documentation built on Nov. 2, 2023, 6:07 p.m.