Learn R Programming

⚠️There's a newer version (2.3.4) of this package.Take me there.

checkmate

Fast and versatile argument checks for R.

Ever used an R function that produced a not-very-helpful error message, just to discover after minutes of debugging that you simply passed a wrong argument?

Blaming the laziness of the package author for not doing such standard checks (in a dynamically typed language such as R) is at least partially unfair, as R makes theses types of checks cumbersome and annoying. Well, that's how it was in the past.

Enter checkmate.

Virtually every standard type of user error when passing arguments into function can be caught with a simple, readable line which produces an informative error message in case. A substantial part of the package was written in C to minimize any worries about execution time overhead. Furthermore, the package provides over 30 expectations to extend the popular testthat package for unit tests.

Installation

For the stable release, just install the latest version from CRAN:

install.packages("checkmate")

For the development version, use devtools:

devtools::install_github("mllg/checkmate")

Resources

Copy Link

Version

Install

install.packages('checkmate')

Monthly Downloads

516,389

Version

2.3.0

License

BSD_3_clause + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Michel Lang

Last Published

October 25th, 2023

Functions in checkmate (2.3.0)

checkAtomic

Check that an argument is an atomic vector
checkAtomicVector

Check that an argument is an atomic vector
anyNaN

Check if an object contains NaN values
AssertCollection

Collect multiple assertions
anyInfinite

Check if an object contains infinite values
checkCharacter

Check if an argument is a vector of type character
checkClass

Check the class membership of an argument
checkCount

Check if an argument is a count
checkDataFrame

Check if an argument is a data frame
checkChoice

Check if an object is an element of a given set
checkDirectoryExists

Check for existence and access rights of directories
checkDisjunct

Check if an argument is disjunct from a given set
checkDataTable

Check if an argument is a data table
checkComplex

Check if an argument is a vector of type complex
checkFunction

Check if an argument is a function
checkFormula

Check if an argument is a formula
checkInt

Check if an argument is a single integerish value
checkDate

Check that an argument is a Date
checkInteger

Check if an argument is vector of type integer
checkFactor

Check if an argument is a factor
checkFALSE

Check if an argument is FALSE
checkFileExists

Check existence and access rights of files
checkFlag

Check if an argument is a flag
checkMatrix

Check if an argument is a matrix
checkLogical

Check if an argument is a vector of type logical
checkMultiClass

Check the class membership of an argument
checkDouble

Check that an argument is a vector of type double
checkNumeric

Check that an argument is a vector of type numeric
checkNumber

Check if an argument is a single numeric value
checkNull

Check if an argument is NULL
checkNames

Check names to comply to specific rules
checkNamed

Check if an argument is named
checkIntegerish

Check if an object is an integerish vector
checkList

Check if an argument is a list
checkScalar

Check if an argument is a single atomic value
checkEnvironment

Check if an argument is an environment
checkScalarNA

Check if an argument is a single missing value
checkR6

Check if an argument is an R6 class
checkRaw

Check if an argument is a raw vector
checkSetEqual

Check if an argument is equal to a given set
checkOS

Check the operating system
checkString

Check if an argument is a string
checkPOSIXct

Check that an argument is a date/time object in POSIXct format
checkmate-package

checkmate: Fast and Versatile Argument Checks
makeTest

Turn a Check into a Test
matchArg

Partial Argument Matching
makeAssertion

Turn a Check into an Assertion
makeExpectation

Turn a Check into an Expectation
checkPermutation

Check if the arguments are permutations of each other.
checkSubset

Check if an argument is a subset of a given set
checkTRUE

Check if an argument is TRUE
checkPathForOutput

Check if a path is suited for creating an output file
%??%

Coalesce operator
checkTibble

Check if an argument is a tibble
wf

Get the index of the first/last TRUE
register_test_backend

Select Backend for Unit Tests
checkVector

Check if an argument is a vector
qassert

Quick argument checks on (builtin) R types
qassertr

Quick recursive arguments checks on lists and data frames
vname

Lookup a variable name
allMissing

Check if an object contains missing values
checkAccess

Check file system access rights
checkArray

Check if an argument is an array
asInteger

Convert an argument to an integer
assert

Combine multiple checks into one assertion