From 1a9c7ee9ac6fa179d836b1fc3d68f10520ce5c7c Mon Sep 17 00:00:00 2001 From: Daniel Sjoberg Date: Mon, 6 May 2024 11:54:52 -0700 Subject: [PATCH] Patch for `construct_model()` (#147) **Reference GitHub issue associated with pull request.** _e.g., 'closes #'_ Related #146 -------------------------------------------------------------------------------- Pre-review Checklist (if item does not apply, mark is as complete) - [ ] **All** GitHub Action workflows pass with a :white_check_mark: - [ ] PR branch has pulled the most recent updates from master branch: `usethis::pr_merge_main()` - [ ] If a bug was fixed, a unit test was added. - [ ] If a new `ard_*()` function was added, it passes the ARD structural checks from `cards::check_ard_structure()`. - [ ] If a new `ard_*()` function was added, `set_cli_abort_call()` has been set. - [ ] If a new `ard_*()` function was added and it depends on another package (such as, `broom`), `is_pkg_installed("broom", reference_pkg = "cardx")` has been set in the function call and the following added to the roxygen comments: `@examplesIf do.call(asNamespace("cardx")$is_pkg_installed, list(pkg = "broom"", reference_pkg = "cardx"))` - [ ] Code coverage is suitable for any new functions/features (generally, 100% coverage for new code): `devtools::test_coverage()` Reviewer Checklist (if item does not apply, mark is as complete) - [ ] If a bug was fixed, a unit test was added. - [ ] Code coverage is suitable for any new functions/features: `devtools::test_coverage()` When the branch is ready to be merged: - [ ] Update `NEWS.md` with the changes from this pull request under the heading "`# cardx (development version)`". If there is an issue associated with the pull request, reference it in parentheses at the end update (see `NEWS.md` for examples). - [ ] **All** GitHub Action workflows pass with a :white_check_mark: - [ ] Approve Pull Request - [ ] Merge the PR. Please use "Squash and merge" or "Rebase and merge". --- R/construction_helpers.R | 6 +++++- tests/testthat/test-ard_stats_anova.R | 4 ++-- tests/testthat/test-construction_helpers.R | 19 +++++++++++++++++++ 3 files changed, 26 insertions(+), 3 deletions(-) diff --git a/R/construction_helpers.R b/R/construction_helpers.R index 47e220cc2..52b867052 100644 --- a/R/construction_helpers.R +++ b/R/construction_helpers.R @@ -117,7 +117,11 @@ construct_model.survey.design <- function(x, formula, method, method.args = list } .as_list_of_exprs <- function(x) { - call_args(enexpr(x)) + x_enexpr <- enexpr(x) + if (tryCatch(inherits(x, "list"), error = \(x) FALSE)) { + return(x) + } + call_args(x_enexpr) } #' @rdname construction_helpers diff --git a/tests/testthat/test-ard_stats_anova.R b/tests/testthat/test-ard_stats_anova.R index db55f67d9..1131cfbea 100644 --- a/tests/testthat/test-ard_stats_anova.R +++ b/tests/testthat/test-ard_stats_anova.R @@ -125,8 +125,8 @@ test_that("ard_stats_anova.data.frame() works", { } ard_anova_geeglm2 <- args_fun(list(id = cyl)) expect_equal( - ard_anova_geeglm2, - ard_anova_geeglm + ard_anova_geeglm2$stat, + ard_anova_geeglm$stat ) }) diff --git a/tests/testthat/test-construction_helpers.R b/tests/testthat/test-construction_helpers.R index 0ff715752..8efbdb0bf 100644 --- a/tests/testthat/test-construction_helpers.R +++ b/tests/testthat/test-construction_helpers.R @@ -30,6 +30,25 @@ test_that("construct_model() works", { "cannot be namespaced" ) + expect_equal( + { + outside_fun <- function() { + method.args <- list() + + construct_model.data.frame( + mtcars, + formula = mpg ~ cyl, + method = "lm", + method.args = method.args + ) |> + coef() + } + + outside_fun() + }, + lm(mpg ~ cyl, mtcars) |> coef() + ) + # now the survey method ------- # styler: off expect_equal({