-
Notifications
You must be signed in to change notification settings - Fork 7
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Additional check functions #86
base: main
Are you sure you want to change the base?
Conversation
cl <- match.call() | ||
arg <- as.character(cl$x) | ||
|
||
for (i in x) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The downside here is that we only catch one violation at a time.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would imagine there's a pretty steep performance penalty here, too. This is the same kind of performance issue that led to tidymodels/parsnip#835.
Maybe an error could be conditional on rlang::is_integerish()
?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is it steep for checking arguments (not data)? We need some sort of (short length) numeric vector checks with min/max/na/null options.
) | ||
} | ||
|
||
# check_logical <- function(x, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
brulee has its own check_logical()
. The is temporary to avoid bringing in a lot of snapshots into this PR.
tests/testthat/test-checkers.R
Outdated
expect_silent(brulee:::check_number_whole_vec(variable)) | ||
expect_silent(brulee:::check_number_whole_vec(variable[1])) | ||
|
||
variable <- seq(0, 1, length.out = 3) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This one demonstrates that you can get a whole number returned that is not an integer data type.
cl <- match.call() | ||
arg <- as.character(cl$x) | ||
|
||
for (i in x) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would imagine there's a pretty steep performance penalty here, too. This is the same kind of performance issue that led to tidymodels/parsnip#835.
Maybe an error could be conditional on rlang::is_integerish()
?
invisible(x) | ||
} | ||
|
||
check_number_decimal_vec <- function(x, call = rlang::caller_env(), ...) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Same edits to this function.
tests/testthat/test-checkers.R
Outdated
library(rlang) | ||
|
||
variable <- "pie" | ||
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) | |
expect_snapshot(check_single_logical(variable), error = TRUE) |
In general, don't need to namespace functions from the package being tested.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
That was left over from testing (since we can source these standalone files)
tests/testthat/test-checkers.R
Outdated
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could you rename either this file or the corresponding R file so that they have the same slug? I.e. either checks
or checkers
but not both.
tests/testthat/test-checkers.R
Outdated
@@ -0,0 +1,50 @@ | |||
test_that("checking single logicals", { | |||
library(rlang) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What do we need this library()
call for? Could it be removed? (Same comment for the other occurrences of this pattern.)
tests/testthat/test-checkers.R
Outdated
variable <- "pie" | ||
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The inputs to the check function here and below are so short, I would inline them into the call inside of expect_snapshot()
so that we can see it in the snapshot .md
file. That makes reviewing those easier.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I want to make sure that the call includes variable
and not the value of the argument. I added one exception here deliberately just to snapshot the in-lined variable (data).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ah, I see! We could combine both ideas like this:
variable <- "pie" | |
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) | |
expect_snapshot(error = TRUE, { | |
variable <- "pie" | |
brulee:::check_single_logical(variable) | |
}) |
tests/testthat/test-checkers.R
Outdated
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) | ||
|
||
variable <- NA | ||
expect_snapshot(brulee:::check_single_logical(variable), error = TRUE) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't see a need to namespace the check function. Could we remove the brulee::
prefix for readability?
R/checks.R
Outdated
check_number_whole_vec <- function(x, call = rlang::caller_env(), ...) { | ||
cl <- match.call() | ||
arg <- as.character(cl$x) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
check_number_whole_vec <- function(x, call = rlang::caller_env(), ...) { | |
cl <- match.call() | |
arg <- as.character(cl$x) | |
check_number_whole_vec <- function(x, arg = rlang::caller_arg(x), call = rlang::caller_env(), ...) { |
Oh, we reviewed both! 👀 |
But at least we didn't contradict each other 😂 |
Co-authored-by: Simon P. Couch <[email protected]>
Worth noting, that a |
Co-authored-by: Emil Hvitfeldt <[email protected]>
The rlang type checkers lack a few functions. This PR has three: one for a single vector and two to check numeric vectors.