test_that("can create a modeling package", {
skip_on_cran()
local_options(usethis.quiet = TRUE)
dir <- withr::local_tempdir("model")
model <- "linear_regression"
# `usethis.quiet = TRUE` silences most of the messages, but there is an
# unavoidable `i Loading model` that we get from devtools if we don't do this
suppressMessages({
create_modeling_package(dir, model, open = FALSE)
})
top_level_files <- list.files(dir)
script_files <- list.files(file.path(dir, "R"))
expect_true("DESCRIPTION" %in% top_level_files)
expect_true("R" %in% top_level_files)
expect_true("man" %in% top_level_files)
expect_true("NAMESPACE" %in% top_level_files)
expect_true(glue::glue("{model}-constructor.R") %in% script_files)
expect_true(glue::glue("{model}-fit.R") %in% script_files)
expect_true(glue::glue("{model}-predict.R") %in% script_files)
})
test_that("can add a second model to a modeling package", {
skip_on_cran()
local_options(usethis.quiet = TRUE)
dir <- withr::local_tempdir("model")
model1 <- "linear_regression"
model2 <- "random_forest"
# `usethis.quiet = TRUE` silences most of the messages, but there is an
# unavoidable `i Loading model` that we get from devtools if we don't do this
suppressMessages({
create_modeling_package(dir, model1, open = FALSE)
})
usethis::with_project(dir, use_modeling_files(model2))
script_files <- list.files(file.path(dir, "R"))
expect_true(glue::glue("{model1}-constructor.R") %in% script_files)
expect_true(glue::glue("{model1}-fit.R") %in% script_files)
expect_true(glue::glue("{model1}-predict.R") %in% script_files)
expect_true(glue::glue("{model2}-constructor.R") %in% script_files)
expect_true(glue::glue("{model2}-fit.R") %in% script_files)
expect_true(glue::glue("{model2}-predict.R") %in% script_files)
})
test_that("no `model` aborts normally", {
expect_snapshot(error = TRUE, create_modeling_package(path = "my/path"))
})
test_that("no `path` aborts normally", {
expect_snapshot(error = TRUE, create_modeling_package(model = "my_model"))
})
test_that("`model` can only be a single string", {
expect_snapshot(error = TRUE, create_modeling_package(path = "my/path", model = c("model1", "model2")))
expect_snapshot(error = TRUE, create_modeling_package(path = "my/path", model = 1))
expect_snapshot(error = TRUE, create_modeling_package(path = "my/path", model = "model with space"))
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.