skip_if_not_installed("modeltests")
library(modeltests)
test_that("ellipsis checking works", {
expect_snapshot(
check_ellipses("exponentiate", "tidy", "boop", exponentiate = TRUE)
)
expect_snapshot(
check_ellipses("exponentiate", "tidy", "boop", exponentiate = TRUE, quick = FALSE)
)
expect_silent(check_ellipses("exponentiate", "tidy", "boop", hi = "pal"))
})
test_that("ellipsis checking works (whole game, tidy)", {
mod <- nls(mpg ~ k * e^wt, data = mtcars, start = list(k = 1, e = 2))
expect_snapshot(tidy(mod, exponentiate = TRUE))
})
test_that("ellipsis checking works (whole game, augment)", {
mod <- kmeans(mtcars, centers = 4)
expect_snapshot(
.res <- augment(mod, data = mtcars, newdata = mtcars)
)
})
test_that("augment_newdata can handle function calls in response term (lm)", {
mt_lm <- lm(data = mtcars, mpg ~ hp)
mt_lm_log <- lm(data = mtcars, log(mpg) ~ hp)
aug_mt_lm_none <- augment(mt_lm)
aug_mt_lm_data <- augment(mt_lm, data = mtcars)
aug_mt_lm_newdata <- augment(mt_lm, newdata = mtcars[1:20, ])
aug_mt_lm_no_resp <- augment(mt_lm, newdata = mtcars[1:20, 2:ncol(mtcars)])
aug_mt_lm_log_none <- augment(mt_lm_log)
aug_mt_lm_log_data <- augment(mt_lm_log, data = mtcars)
aug_mt_lm_log_newdata <- augment(mt_lm_log, newdata = mtcars[1:20, ])
aug_mt_lm_log_no_resp <- augment(mt_lm_log, newdata = mtcars[1:20, 2:ncol(mtcars)])
expect_true(inherits(aug_mt_lm_log_none, "tbl_df"))
expect_true(inherits(aug_mt_lm_log_data, "tbl_df"))
expect_true(inherits(aug_mt_lm_log_newdata, "tbl_df"))
expect_true(inherits(aug_mt_lm_log_no_resp, "tbl_df"))
expect_equal(".resid" %in% colnames(aug_mt_lm_log_none), ".resid" %in% colnames(aug_mt_lm_none))
expect_equal(".resid" %in% colnames(aug_mt_lm_log_data), ".resid" %in% colnames(aug_mt_lm_data))
expect_equal(".resid" %in% colnames(aug_mt_lm_log_newdata), ".resid" %in% colnames(aug_mt_lm_newdata))
expect_equal(".resid" %in% colnames(aug_mt_lm_log_no_resp), ".resid" %in% colnames(aug_mt_lm_no_resp))
expect_equal(aug_mt_lm_log_none$.resid, log(mtcars$mpg) - unname(fitted(mt_lm_log, mtcars)))
expect_equal(aug_mt_lm_log_data$.resid, log(mtcars$mpg) - unname(fitted(mt_lm_log, mtcars)))
expect_equal(aug_mt_lm_log_newdata$.resid, log(mtcars$mpg[1:20]) - unname(predict(mt_lm_log, mtcars[1:20, ])))
})
test_that("augment_newdata can handle function calls in response term (glm)", {
mt_glm <- glm(data = mtcars, mpg ~ .)
mt_glm_log <- glm(data = mtcars, log(mpg) ~ .)
aug_mt_glm_none <- augment(mt_glm)
aug_mt_glm_data <- augment(mt_glm, data = mtcars)
aug_mt_glm_newdata <- augment(mt_glm, newdata = mtcars[1:20, ])
aug_mt_glm_no_resp <- augment(mt_glm, newdata = mtcars[1:20, 2:ncol(mtcars)])
aug_mt_glm_log_none <- augment(mt_glm_log)
aug_mt_glm_log_data <- augment(mt_glm_log, data = mtcars)
aug_mt_glm_log_newdata <- augment(mt_glm_log, newdata = mtcars[1:20, ])
aug_mt_glm_log_no_resp <- augment(mt_glm_log, newdata = mtcars[1:20, 2:ncol(mtcars)])
expect_true(inherits(aug_mt_glm_log_none, "tbl_df"))
expect_true(inherits(aug_mt_glm_log_data, "tbl_df"))
expect_true(inherits(aug_mt_glm_log_newdata, "tbl_df"))
expect_true(inherits(aug_mt_glm_log_no_resp, "tbl_df"))
expect_equal(".resid" %in% colnames(aug_mt_glm_log_none), ".resid" %in% colnames(aug_mt_glm_none))
expect_equal(".resid" %in% colnames(aug_mt_glm_log_data), ".resid" %in% colnames(aug_mt_glm_data))
expect_equal(".resid" %in% colnames(aug_mt_glm_log_newdata), ".resid" %in% colnames(aug_mt_glm_newdata))
expect_equal(".resid" %in% colnames(aug_mt_glm_log_no_resp), ".resid" %in% colnames(aug_mt_glm_no_resp))
expect_equal(aug_mt_glm_log_none$.resid, log(mtcars$mpg) - unname(fitted(mt_glm_log, mtcars)))
expect_equal(aug_mt_glm_log_data$.resid, log(mtcars$mpg) - unname(fitted(mt_glm_log, mtcars)))
})
test_that("augment_newdata can handle function calls in response term (loess)", {
mt_loess <- loess(data = mtcars, mpg ~ hp + disp)
mt_loess_log <- loess(data = mtcars, log(mpg) ~ hp + disp)
aug_mt_loess_none <- augment(mt_loess)
aug_mt_loess_data <- augment(mt_loess, data = mtcars)
aug_mt_loess_newdata <- augment(mt_loess, newdata = mtcars[1:20, ])
aug_mt_loess_no_resp <- augment(mt_loess, newdata = mtcars[1:20, 2:ncol(mtcars)])
aug_mt_loess_log_none <- augment(mt_loess_log)
aug_mt_loess_log_data <- augment(mt_loess_log, data = mtcars)
aug_mt_loess_log_newdata <- augment(mt_loess_log, newdata = mtcars[1:20, ])
aug_mt_loess_log_no_resp <- augment(mt_loess_log, newdata = mtcars[1:20, 2:ncol(mtcars)])
expect_true(inherits(aug_mt_loess_log_none, "tbl_df"))
expect_true(inherits(aug_mt_loess_log_data, "tbl_df"))
expect_true(inherits(aug_mt_loess_log_newdata, "tbl_df"))
expect_true(inherits(aug_mt_loess_log_no_resp, "tbl_df"))
expect_equal(".resid" %in% colnames(aug_mt_loess_log_none), ".resid" %in% colnames(aug_mt_loess_none))
expect_equal(".resid" %in% colnames(aug_mt_loess_log_data), ".resid" %in% colnames(aug_mt_loess_data))
expect_equal(".resid" %in% colnames(aug_mt_loess_log_newdata), ".resid" %in% colnames(aug_mt_loess_newdata))
expect_equal(".resid" %in% colnames(aug_mt_loess_log_no_resp), ".resid" %in% colnames(aug_mt_loess_no_resp))
expect_equal(aug_mt_loess_log_none$.resid, log(mtcars$mpg) - unname(fitted(mt_loess_log, mtcars)))
expect_equal(aug_mt_loess_log_data$.resid, log(mtcars$mpg) - unname(fitted(mt_loess_log, mtcars)))
expect_equal(aug_mt_loess_log_newdata$.resid, log(mtcars$mpg[1:20]) - unname(predict(mt_loess_log, mtcars[1:20, ])))
})
test_that("as_glance_tibble", {
df1 <- as_glance_tibble(x = 1, y = 1, na_types = "rr")
df2 <- as_glance_tibble(x = 1, y = NULL, na_types = "rc")
df3 <- as_glance_tibble(x = 1, y = NULL, na_types = "rr")
expect_equal(
purrr::map(df1, class),
purrr::map(df3, class)
)
expect_true(class(df1$y) == class(df3$y))
expect_false(class(df1$y) == class(df2$y))
expect_snapshot(error = TRUE, as_glance_tibble(x = 1, y = 1, na_types = "rrr"))
})
test_that("appropriate warning on (g)lm-subclassed models", {
x <- 1
class(x) <- c("boop", "glm")
expect_snapshot(warn_on_subclass(x, "tidy"))
# only displayed once per session, per unique dispatch
expect_silent(warn_on_subclass(x, "tidy"))
class(x) <- c("bop", "glm", "lm")
expect_snapshot(warn_on_subclass(x, "tidy"))
# only displayed once per session, per unique dispatch
expect_silent(
warn_on_subclass(x, "tidy")
)
})
test_that("as_augment_tibble errors informatively", {
m <- matrix(1:4, ncol = 2)
expect_snapshot(error = TRUE, as_augment_tibble(m))
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.