Nothing
test_that("linter returns correct linting", {
linter <- undesirable_function_linter(fun = c(return = NA, log10 = "use log()"))
msg_return <- rex::rex('Avoid undesirable function "return".', end)
msg_log10 <- rex::rex('Avoid undesirable function "log10". As an alternative, use log().')
expect_no_lint("x <- options()", linter)
expect_no_lint("cat(\"Try to return\")", linter)
expect_lint("lapply(x, log10)", list(message = msg_log10, line_number = 1L, column_number = 11L), linter)
expect_lint("return()", list(message = msg_return, line_number = 1L, column_number = 1L), linter)
expect_lint(
trim_some("
function(x) {
print(options())
y <- log10(x)
return(y)
}"),
list(
list(message = msg_log10, line_number = 3L, column_number = 8L),
list(message = msg_return, line_number = 4L, column_number = 3L)
),
linter
)
# regression test for #1050
expect_no_lint("df$return <- 1", linter)
expect_no_lint("df@return <- 1", linter)
})
test_that("it's possible to NOT lint symbols", {
linter <- undesirable_function_linter(
fun = c(dir = NA, log10 = "use log()"),
symbol_is_undesirable = FALSE
)
expect_no_lint("dir <- 'path/to/a/directory'", linter)
expect_no_lint("lapply(x, log10)", linter)
})
test_that("undesirable_function_linter doesn't lint library and require calls", {
linter <- undesirable_function_linter(fun = c(foo = NA))
expect_lint("test::foo()", "undesirable", linter)
expect_no_lint("foo::test()", linter)
expect_no_lint("library(foo)", linter)
expect_no_lint("require(foo)", linter)
linter <- undesirable_function_linter(fun = c(foo = NA, bar = NA))
expect_no_lint("library(foo)", linter)
linter <- undesirable_function_linter(fun = c(foo = NA, bar = NA), symbol_is_undesirable = FALSE)
expect_no_lint("library(foo)", linter)
})
# regression test for #866
test_that("Line numbers are extracted correctly", {
lines <- c(rep(letters, 10L), "tmp <- tempdir()")
expect_lint(paste(lines, collapse = "\n"), "undesirable", undesirable_function_linter(c(tempdir = NA)))
})
test_that("invalid inputs fail correctly", {
expect_error(
undesirable_function_linter(fun = NULL),
"`fun` should be a non-empty character vector",
fixed = TRUE
)
expect_error(
undesirable_function_linter(fun = character(0L)),
"`fun` should be a non-empty character vector",
fixed = TRUE
)
expect_error(
undesirable_function_linter(c(NA, NA)),
rex::rex("Unnamed elements of `fun` must not be missing", anything, "1", anything, "2")
)
expect_error(
undesirable_function_linter(symbol_is_undesirable = 1.0),
"is.logical(symbol_is_undesirable) is not TRUE",
fixed = TRUE
)
})
test_that("Default recommendations can be specified multiple ways", {
linter_na <- undesirable_function_linter(c(foo = NA))
linter_unnamed1 <- undesirable_function_linter("foo")
linter_unnamed2 <- undesirable_function_linter(c("foo", "bar"))
linter_mixed1 <- undesirable_function_linter(c("foo", bar = "no bar"))
linter_mixed2 <- undesirable_function_linter(c("foo", bar = NA))
lint_message <- rex::rex('Avoid undesirable function "foo"')
lint_str <- "foo()"
expect_lint(lint_str, lint_message, linter_na)
expect_lint(lint_str, lint_message, linter_unnamed1)
expect_lint(lint_str, lint_message, linter_unnamed2)
expect_lint(lint_str, lint_message, linter_mixed1)
expect_lint(lint_str, lint_message, linter_mixed2)
})
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.