https://github.com/hadley/assertthat
User friendly assertions for R
https://github.com/hadley/assertthat
Last synced: 5 days ago
JSON representation
User friendly assertions for R
- Host: GitHub
- URL: https://github.com/hadley/assertthat
- Owner: hadley
- Created: 2013-04-09T15:17:53.000Z (about 12 years ago)
- Default Branch: master
- Last Pushed: 2023-04-21T14:55:10.000Z (almost 2 years ago)
- Last Synced: 2025-04-09T19:19:53.848Z (5 days ago)
- Language: R
- Size: 121 KB
- Stars: 208
- Watchers: 5
- Forks: 29
- Open Issues: 34
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- jimsghstars - hadley/assertthat - User friendly assertions for R (R)
README
# assertthat
[](https://travis-ci.org/hadley/assertthat)
[](https://codecov.io/github/hadley/assertthat?branch=master)assertthat provides a drop in replacement for `stopifnot()` that makes it easy to check the pre- and post-conditions of a function, while producing useful error messages.
```R
x <- 1:10
stopifnot(is.character(x))
# Error: is.character(x) is not TRUEassert_that(is.character(x))
# Error: x is not a character vectorassert_that(length(x) == 5)
# Error: length(x) not equal to 5assert_that(is.numeric(x))
# [1] TRUE
```This is a good defensive programming technique, and is useful as source-code documentation: you can see exactly what your function expects when you come back to it in the future. It is partly a response to the lack of static typing in R, but it allows you to test for general conditions (like `length(x) == length(y)`) that are difficult to express in a type system.
`assertthat` can be installed either from CRAN:
```R
install.packages('assertthat')
```or with devtools:
```R
devtools::install_github("hadley/assertthat")
```## New assertions
As well as all the functions provided by R, assertthat provides a few more that I use a lot:
* `is.flag(x)`: is x `TRUE` or `FALSE`? (a boolean flag)
* `is.string(x)`: is x a length 1 character vector?
* `has_name(x, nm)`, `x %has_name% nm`: does `x` have component `nm`?
* `has_attr(x, attr)`, `x %has_attr% attr`: does `x` have attribute `attr`?
* `is.count(x)`: is x a single positive integer?
* `are_equal(x, y)`: are `x` and `y` equal?
* `not_empty(x)`: are all dimensions of `x` greater than 0?
* `noNA(x)`: is `x` free from missing values?
* `is.dir(path)`: is `path` a directory?
* `is.writeable(path)`/`is.readable(path)`: is `path` writeable/readable?
* `has_extension(path, extension)`: does `file` have given `extension`?## `assert_that`, `see_if` and `validate_that`
There are three main functions in assertthat:
* `assert_that()` signal an error
* `see_if()` returns a logical value, with the error message as an attribute.
* `validate_that()` returns `TRUE` on success, otherwise returns the error as
a string.You'll use `assert_that()` in your own code, but you'll mostly see `see_if()` in the examples (because `R CMD check` requires that examples run without errors). Use `validate_that()` for S4 validate methods.
## Writing your own assertions
If you're writing your own assertions, you can provide custom error messages using the `on_failure()` helper:
```R
is_odd <- function(x) {
assert_that(is.numeric(x), length(x) == 1)
x %% 2 == 1
}
assert_that(is_odd(2))
# Error: is_odd(x = 2) is not TRUEon_failure(is_odd) <- function(call, env) {
paste0(deparse(call$x), " is even")
}
assert_that(is_odd(2))
# Error: 2 is even
```The `on_failure` callback is called with two arguments, the unevaluated function `call` (which has already been standardised with `match.call()`), and `env`, and the environment in which the assertion was executed. This allows you to choose between displaying values or names in your error messages. Read the [advanced R book](http://adv-r.had.co.nz/Expressions.html) to learn more about working with calls.
Also note the use of `assert_that()` in our new function: assertions flow through function calls ensuring that you get a useful error message at the top level:
```R
assert_that(is_odd("b"))
# Error: x is not a numeric or integer vector
assert_that(is_odd(1:2))
# Error: length(x) not equal to 1
```