Learn R Programming

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

290,214

Version

2.3.3

License

BSD_3_clause + file LICENSE

Issues

Pull Requests

Stars

Forks

Maintainer

Michel Lang

Last Published

August 18th, 2025

Functions in checkmate (2.3.3)

checkClass

Check the class membership of an argument
checkComplex

Check if an argument is a vector of type complex
checkDate

Check that an argument is a Date
checkChoice

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

Check if an argument is a vector of type character
checkDataFrame

Check if an argument is a data frame
checkDirectoryExists

Check for existence and access rights of directories
checkDisjunct

Check if an argument is disjunct from a given set
checkCount

Check if an argument is a count
checkDataTable

Check if an argument is a data table
checkFlag

Check if an argument is a flag
checkFileExists

Check existence and access rights of files
checkFormula

Check if an argument is a formula
checkDouble

Check that an argument is a vector of type double
checkInteger

Check if an argument is vector of type integer
checkFunction

Check if an argument is a function
checkEnvironment

Check if an argument is an environment
checkInt

Check if an argument is a single integerish value
checkFALSE

Check if an argument is FALSE
checkFactor

Check if an argument is a factor
checkMultiClass

Check the class membership of an argument
checkNamed

Check if an argument is named
checkLogical

Check if an argument is a vector of type logical
checkIntegerish

Check if an object is an integerish vector
checkNumeric

Check that an argument is a vector of type numeric
checkNumber

Check if an argument is a single numeric value
checkMatrix

Check if an argument is a matrix
checkNull

Check if an argument is NULL
checkNames

Check names to comply to specific rules
checkList

Check if an argument is a list
checkString

Check if an argument is a string
checkPathForOutput

Check if a path is suited for creating an output file
checkRaw

Check if an argument is a raw vector
checkSetEqual

Check if an argument is equal to a given set
checkPOSIXct

Check that an argument is a date/time object in POSIXct format
checkScalar

Check if an argument is a single atomic value
checkOS

Check the operating system
checkPermutation

Check if the arguments are permutations of each other.
checkR6

Check if an argument is an R6 class
checkScalarNA

Check if an argument is a single missing value
%??%

Coalesce operator
makeAssertion

Turn a Check into an Assertion
makeExpectation

Turn a Check into an Expectation
checkTibble

Check if an argument is a tibble
checkSubset

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

Check if an argument is TRUE
matchArg

Partial Argument Matching
makeTest

Turn a Check into a Test
vname

Lookup a variable name
wf

Get the index of the first/last TRUE
register_test_backend

Select Backend for Unit Tests
checkmate-package

checkmate: Fast and Versatile Argument Checks
checkVector

Check if an argument is a vector
qassertr

Quick recursive arguments checks on lists and data frames
qassert

Quick argument checks on (builtin) R types
checkAtomicVector

Check that an argument is an atomic vector
AssertCollection

Collect multiple assertions
checkAccess

Check file system access rights
checkArray

Check if an argument is an array
anyNaN

Check if an object contains NaN values
asInteger

Convert an argument to an integer
anyInfinite

Check if an object contains infinite values
assert

Combine multiple checks into one assertion
checkAtomic

Check that an argument is an atomic vector
allMissing

Check if an object contains missing values