Skip to content

Commit

Permalink
#473 assert_length: improve coverage
Browse files Browse the repository at this point in the history
  • Loading branch information
bundfussr committed Dec 3, 2024
1 parent 5b10154 commit 3b7c9ed
Show file tree
Hide file tree
Showing 2 changed files with 146 additions and 138 deletions.
52 changes: 26 additions & 26 deletions tests/testthat/_snaps/assertions.md
Original file line number Diff line number Diff line change
Expand Up @@ -212,7 +212,7 @@
Error in `example_fun()`:
! Argument `arg` must be an integer scalar.

# assert_numeric_vector Test 37: error if `arg` is not a numeric vector
# assert_numeric_vector Test 38: error if `arg` is not a numeric vector

Code
example_fun(TRUE)
Expand All @@ -236,31 +236,31 @@
Error in `example_fun()`:
! Argument `arg` must be a numeric vector, but it is a string.

# assert_numeric_vector Test 38: error if length is not as expected
# assert_numeric_vector Test 39: error if length is not as expected

Code
assert_numeric_vector(numbers, length = 2)
Condition
Error:
! Argument `numbers` must be a vector of length 2, but has length 3.

# assert_s3_class Test 39: error if `arg` is not an object of a specific class S3
# assert_s3_class Test 40: error if `arg` is not an object of a specific class S3

Code
example_fun("test")
Condition
Error in `example_fun()`:
! Argument `arg` must be class <factor>, but is a string.

# assert_s3_class Test 41: error if `arg` is NULL and optional is FALSE
# assert_s3_class Test 42: error if `arg` is NULL and optional is FALSE

Code
example_fun(NULL)
Condition
Error in `example_fun()`:
! Argument `arg` must be class <factor>, but is NULL.

# assert_list_of Test 43: error if `arg` is not a list of specific class S3 objects
# assert_list_of Test 44: error if `arg` is not a list of specific class S3 objects

Code
example_fun(list("test"))
Expand All @@ -269,15 +269,15 @@
! Each element of the list in argument `arg` must be class/type <factor>.
i But, element 1 is a string

# assert_list_of Test 45: error if `arg` is NULL and optional is FALSE
# assert_list_of Test 46: error if `arg` is NULL and optional is FALSE

Code
example_fun(NULL)
Condition
Error in `example_fun()`:
! Argument `arg` must be class <list>, but is NULL.

# assert_list_of Test 47: error if `arg` is not a named list (no elements named)
# assert_list_of Test 48: error if `arg` is not a named list (no elements named)

Code
mylist <- list(1, 2, 3)
Expand All @@ -287,7 +287,7 @@
! All elements of `mylist` argument must be named.
i The indices of the unnamed elements are 1, 2, and 3

# assert_list_of Test 48: error if `arg` is not a named list (some elements named)
# assert_list_of Test 49: error if `arg` is not a named list (some elements named)

Code
mylist <- list(1, 2, 3, d = 4)
Expand All @@ -297,7 +297,7 @@
! All elements of `mylist` argument must be named.
i The indices of the unnamed elements are 1, 2, and 3

# assert_named Test 51: error if no elements are named
# assert_named Test 52: error if no elements are named

Code
arg <- c(1, 2)
Expand All @@ -307,15 +307,15 @@
! All elements of `arg` argument must be named.
i The indices of the unnamed elements are 1 and 2

# assert_function Test 52: error if `arg` is not a function
# assert_function Test 53: error if `arg` is not a function

Code
example_fun(5)
Condition
Error in `example_fun()`:
! Argument `arg` must be a function, but is a number.

# assert_function Test 55: error if `params` is missing with no default
# assert_function Test 56: error if `params` is missing with no default

Code
example_fun(sum)
Expand All @@ -331,23 +331,23 @@
Error in `example_fun()`:
! "x" and "y" are not arguments of the function specified for `arg`.

# assert_unit Test 60: error if multiple units in the input dataset
# assert_unit Test 61: error if multiple units in the input dataset

Code
assert_unit(advs, param = "WEIGHT", get_unit_expr = VSSTRESU)
Condition
Error:
! Multiple units "kg" and "lb" found for "WEIGHT". Please review and update the units.

# assert_unit Test 61: error if unexpected unit in the input dataset
# assert_unit Test 62: error if unexpected unit in the input dataset

Code
assert_unit(advs, param = "WEIGHT", required_unit = "lb", get_unit_expr = VSSTRESU)
Condition
Error:
! It is expected that "WEIGHT" has unit of "lb". In the input dataset the unit is "kg".

# assert_unit Test 62: error if get_unit_expr invalid
# assert_unit Test 63: error if get_unit_expr invalid

Code
assert_unit(advs, param = "WEIGHT", required_unit = "kg", get_unit_expr = VSTRESU)
Expand All @@ -357,15 +357,15 @@
See error message below:
i In argument: `_unit = VSTRESU`. Caused by error: ! object 'VSTRESU' not found

# assert_param_does_not_exist Test 63: error if parameter exists in the input dataset
# assert_param_does_not_exist Test 64: error if parameter exists in the input dataset

Code
assert_param_does_not_exist(advs, param = "WEIGHT")
Condition
Error:
! The parameter code "WEIGHT" already exists in dataset `advs`.

# assert_varval_list Test 65: error if `arg` is not a list of var-value expressions
# assert_varval_list Test 66: error if `arg` is not a list of expressions

Code
example_fun(c("USUBJID", "PARAMCD", "VISIT"))
Expand All @@ -374,7 +374,7 @@
! Argument `arg` must be a named list of expressions where each element is a symbol, character scalar, numeric scalar, an expression, or NA, but is a character vector.
i To create a list of expressions use `exprs()`.

# assert_varval_list Test 66: error if `arg` is not a list of var-value expressions
# assert_varval_list Test 67: error if not all elements are variables

Code
example_fun(exprs(USUBJID, PARAMCD, NULL))
Expand All @@ -383,15 +383,15 @@
! Argument `arg` must be a list of expressions where each element is a symbol, character scalar, numeric scalar, an expression, or NA, but is a list.
i To create a list of expressions use `exprs()`.

# assert_varval_list Test 67: error if `required_elements` are missing from `arg`
# assert_varval_list Test 68: error if `required_elements` are missing from `arg`

Code
example_fun(exprs(DTHSEQ = AESEQ))
Condition
Error in `example_fun()`:
! The following required elements are missing from argument `arg`: "DTHDOM".

# assert_varval_list Test 69: error if `accept_expr` is TRUE and value is invalid
# assert_varval_list Test 70: error if `accept_expr` is TRUE and value is invalid

Code
example_fun(exprs(DTHSEQ = TRUE))
Expand All @@ -400,7 +400,7 @@
! The elements of the list in argument `arg` must be a symbol, character scalar, numeric scalar, an expression, or NA.
i "DTHSEQ" = `TRUE` is of type <logical>

# assert_varval_list Test 70: error if `accept_expr` is FALSE and value is invalid
# assert_varval_list Test 71: error if `accept_expr` is FALSE and value is invalid

Code
example_fun(exprs(DTHSEQ = exprs()))
Expand All @@ -409,7 +409,7 @@
! The elements of the list in argument `arg` must be a symbol, character scalar, numeric scalar, or NA.
i "DTHSEQ" = `exprs()` is of type <language>

# assert_list_element Test 79: error if the elements do not fulfill the condition
# assert_list_element Test 80: error if the elements do not fulfill the condition

Code
assert_list_element(list(list(var = expr(DTHDT), val = 1), list(var = expr(
Expand All @@ -433,7 +433,7 @@
! List element "val" must one of 0 and 1 in argument `input`.
i But, `input[[2]]$val = -1`, and `input[[3]]$val = -2`

# assert_one_to_one Test 80: error if there is a one to many mapping
# assert_one_to_one Test 81: error if there is a one to many mapping

Code
assert_one_to_one(dm, exprs(DOMAIN), exprs(USUBJID))
Expand All @@ -442,31 +442,31 @@
! For some values of "DOMAIN" there is more than one value of "USUBJID"
i Call `admiral::get_one_to_many_dataset()` to get all one-to-many values.

# assert_date_var Test 83: error if variable is not a date or datetime variable
# assert_date_var Test 84: error if variable is not a date or datetime variable

Code
example_fun(dataset = my_data, var = USUBJID)
Condition
Error in `example_fun()`:
! Column "USUBJID" in dataset `dataset` must be a date or datetime, but is a character vector.

# assert_date_vector Test 87: error if `arg` is NULL and optional is FALSE
# assert_date_vector Test 88: error if `arg` is NULL and optional is FALSE

Code
example_fun(NULL)
Condition
Error in `example_fun()`:
! Argument `arg` must be a date or datetime, but is NULL.

# assert_atomic_vector Test 88: error if input is not atomic vector
# assert_atomic_vector Test 89: error if input is not atomic vector

Code
assert_atomic_vector(x)
Condition
Error:
! Argument `x` must be an atomic vector, but is a list.

# assert_same_type Test 90: error if different type
# assert_same_type Test 91: error if different type

Code
assert_same_type(true_value, false_value, missing_value)
Expand Down
Loading

0 comments on commit 3b7c9ed

Please sign in to comment.