tests/testthat/test-helpers-pull_parsnip_preprocessor.R

# Data
m750 <- timetk::m4_monthly %>% dplyr::filter(id == "M750")

# Split Data 80/20
splits <- rsample::initial_time_split(m750, prop = 0.9)


# * (MATRIX) ARIMA ----


test_that("arima - matrix interface", {

    skip_on_cran()

    form <- stats::formula("log(value) ~ date")

    model_fit_no_boost <- arima_reg() %>%
        parsnip::set_engine(engine = "auto_arima") %>%
        fit(form, data = rsample::training(splits))

    form_extract <- model_fit_no_boost %>% pull_parsnip_preprocessor()

    expect_equal(form, form_extract)

})


# (FORMULA - S3) MARS ----

test_that("MARS - S3 FORMULA", {
    skip_if_not_installed("earth")
    skip_on_cran()

    form <- stats::formula("log(value) ~ as.numeric(date) + lubridate::month(date, label = TRUE)")
    model_fit_mars <- mars(mode = "regression") %>%
        parsnip::set_engine("earth") %>%
        fit(form, data = rsample::training(splits))

    form_extract <- model_fit_mars %>% pull_parsnip_preprocessor()

    expect_equal(form, form_extract)

})

# (FORMULA - S4) SVM ----


test_that("SVM - S4 FORMULA", {
    skip_if_not_installed("kernlab")
    skip_on_cran()

    form <- stats::formula("log(value) ~ as.numeric(date) + lubridate::month(date, label = TRUE)")

    model_fit_svm <- svm_rbf(mode = "regression") %>%
        parsnip::set_engine("kernlab") %>%
        fit(form, data = rsample::training(splits))

    form_extract <- model_fit_svm %>% pull_parsnip_preprocessor()

    expect_equal(form, form_extract)

})

# ERROR ----

test_that("pull_parsnip_preprocessor error", {

    skip_on_cran()

    expect_error(pull_parsnip_preprocessor(1))

})

Try the modeltime package in your browser

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

modeltime documentation built on Oct. 23, 2024, 1:07 a.m.