knitr::opts_chunk$set(
  collapse = TRUE,
  comment = "#>",
  fig.path = "man/figures/README-",
  out.width = "100%"
)

sealr

CRAN_Status_Badge CRAN RStudio mirror downloads minimal R version Depsy

Travis build status Coverage status

lifecycle npm

Motivation

Data is not always what you think. Someone may change a single value or the data type may be different depending on the specification the API. We need to be aware of these data changes as soon as possible (It is hard to review from the final result!).

You can use tests and asserts to check data behavior. Although the testthat package is originally used for unit test of R package, this framework is wide and applicable to any R object. On the other hand, it is time-consuming task to enter the state of existing objects, and there is a possibility of mistakes as well.

The goal of sealr is to reduce the burden of writing unit tests and assertion that record the state of objects. Applying a function of sealr to the target object outputs the test code that record the current state.

Installation

sealr is available on CRAN.

install.packages("sealr")

For developers, install from GitHub.

install.packages("devtools")
devtools::install_github("uribo/sealr")

How to use

  1. (As usual) Create an R object.
  2. Execute the function of sealr (design_*() or transcribe()) against a object whose state is to be record.
    • design_*()... The preamble is fixed and consists of the function name bearing test items (eg. design_class(), design_length(), etc.).
    • transcribe()... Sets of design_*().It is a generic function and returns combinations according to the class of the object.
library(sealr)
library(testthat)
x <- seq(1, 9, by = 2)

design_class(x, seal = TRUE)

design_range(x, seal = TRUE)

You can copy the output, but if you activate the clip argument, the output result will be in a copied state, pasting that value is too easy. This feature depends on the clipr package.

design_class(x, seal = TRUE, clip = TRUE)
expect_is(
  x,
  "numeric"
)

transcribe() is a generic function that produces output according to the class of the object. Currently it suports to 8 classes, but we plan to add various classes in future upgrades.

transcribe(iris)

my_data <- list(A = letters, B = trees)

transcribe(my_data, load_testthat = FALSE, ts = FALSE)

To get started, please read our introduce vignette.

Related projects on the test and assertion

Code of Conduct

Please note that this project is released with a Contributor Code of Conduct.

By participating in this project you agree to abide by its terms.



uribo/sealr documentation built on May 26, 2019, 5:34 a.m.