From ee5e7de1a2c604c02a88367d85c97c12654c9ca4 Mon Sep 17 00:00:00 2001 From: dgkf <18220321+dgkf@users.noreply.github.com> Date: Thu, 4 Apr 2024 12:57:04 -0400 Subject: [PATCH] v0.1.0 release version --- R/testthat.R | 38 +++++++++++++++++--------------- man/test_examples_as_testthat.Rd | 5 +++-- man/testex-testthat.Rd | 9 ++++---- tests/spelling.R | 10 ++++++--- 4 files changed, 35 insertions(+), 27 deletions(-) diff --git a/R/testthat.R b/R/testthat.R index d8b5af3..d3a420d 100644 --- a/R/testthat.R +++ b/R/testthat.R @@ -17,14 +17,14 @@ #' tests. #' @inheritParams testex #' -#' @examples -#' library(testthat) -#' +#' @examplesIf requireNamespace("testthat", quietly = TRUE) #' # example code #' 1 + 2 #' #' # within `testthat_block`, test code refers to previous result with `.` -#' testthat_block({ +#' testthat_block({ \dontshow{ +#' . <- 3 # needed because roxygen2 @examplesIf mutates .Last.value +#' } #' test_that("addition holds up", { #' expect_equal(., 3) #' }) @@ -52,9 +52,9 @@ NULL #' @return The result of evaluating provided expressions #' #' @export -testthat_block <- function(..., value = get_example_value(), obj = NULL, - example = NULL, tests = NULL, envir = parent.frame()) { - +testthat_block <- function( + ..., value = get_example_value(), obj = NULL, + example = NULL, tests = NULL, envir = parent.frame()) { if (!missing(value)) value <- substitute(value) exprs <- substitute(...()) @@ -168,23 +168,22 @@ fallback_expect_no_error <- function(object, ...) { #' @return The result of [`testthat::source_file()`], after iterating over #' generated test files. #' -#' @examples +#' @examplesIf requireNamespace("testthat", quietly = TRUE) #' \donttest{ -#' library(pkg.example) # from /inst/pkg.example +#' # library(pkg.example) #' path <- system.file("pkg.example", package = "testex") #' test_examples_as_testthat(path = path) #' } #' #' @export test_examples_as_testthat <- function( - package, path, ..., test_dir = tempfile("testex"), clean = TRUE, - overwrite = TRUE, reporter = testthat::get_reporter() -) { + package, path, ..., test_dir = tempfile("testex"), clean = TRUE, + overwrite = TRUE, reporter = testthat::get_reporter()) { requireNamespace("testthat") testthat_envvar_val <- Sys.getenv("TESTTHAT") Sys.setenv(TESTTHAT = "true") - on.exit(Sys.setenv(TESTTHAT = testthat_envvar_val)) + on.exit(Sys.setenv(TESTTHAT = testthat_envvar_val), add = TRUE) if (missing(path)) { path <- find_package_root(testthat::test_path()) @@ -195,10 +194,10 @@ test_examples_as_testthat <- function( if (!test_dir_exists) { dir.create(test_dir) - if (clean) on.exit(unlink(test_dir)) + if (clean) on.exit(unlink(test_dir), add = TRUE) } - if (test_dir_exists && !overwrite) { + if (test_dir_exists && !overwrite) { test_files <- list.files(test_dir, full.names = TRUE) test_files(test_files, chdir = FALSE, "examples [run from testex]") return() @@ -216,7 +215,7 @@ test_examples_as_testthat <- function( exprs[is_ex] <- lapply( exprs[is_ex], wrap_expect_no_error, - value = quote(..Last.value) # can't use base::.Last.value in testthat env + value = quote(..Last.value) # can't use base::.Last.value in testthat env ) # write out test code to file in test dir @@ -285,6 +284,9 @@ wrap_expect_no_error <- function(expr, value) { #' #' @keywords internal get_example_value <- function() { - if (testthat::is_testing()) quote(..Last.value) - else quote(.Last.value) + if (testthat::is_testing()) { + quote(..Last.value) + } else { + quote(.Last.value) + } } diff --git a/man/test_examples_as_testthat.Rd b/man/test_examples_as_testthat.Rd index 169593b..f2061db 100644 --- a/man/test_examples_as_testthat.Rd +++ b/man/test_examples_as_testthat.Rd @@ -57,10 +57,11 @@ It is assumed that this function is used within a \code{testthat} run, when the necessary packages are already installed and loaded. } \examples{ +\dontshow{if (requireNamespace("testthat", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} \donttest{ -library(pkg.example) # from /inst/pkg.example +# library(pkg.example) path <- system.file("pkg.example", package = "testex") test_examples_as_testthat(path = path) } - +\dontshow{\}) # examplesIf} } diff --git a/man/testex-testthat.Rd b/man/testex-testthat.Rd index a962aa2..50050d5 100644 --- a/man/testex-testthat.Rd +++ b/man/testex-testthat.Rd @@ -85,13 +85,14 @@ code. }} \examples{ -library(testthat) - +\dontshow{if (requireNamespace("testthat", quietly = TRUE)) (if (getRversion() >= "3.4") withAutoprint else force)(\{ # examplesIf} # example code 1 + 2 # within `testthat_block`, test code refers to previous result with `.` -testthat_block({ +testthat_block({ \dontshow{ + . <- 3 # needed because roxygen2 mutates .Last.value + } test_that("addition holds up", { expect_equal(., 3) }) @@ -101,5 +102,5 @@ testthat_block({ with_srcref("abc.R:1:3", expect_equal(., 3)) }) }) - +\dontshow{\}) # examplesIf} } diff --git a/tests/spelling.R b/tests/spelling.R index 6713838..d60e024 100644 --- a/tests/spelling.R +++ b/tests/spelling.R @@ -1,3 +1,7 @@ -if(requireNamespace('spelling', quietly = TRUE)) - spelling::spell_check_test(vignettes = TRUE, error = FALSE, - skip_on_cran = TRUE) +if (requireNamespace("spelling", quietly = TRUE)) { + spelling::spell_check_test( + vignettes = TRUE, + error = FALSE, + skip_on_cran = TRUE + ) +}