Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/r-lib/waldo
Find differences between R objects
https://github.com/r-lib/waldo
diff r testing
Last synced: about 5 hours ago
JSON representation
Find differences between R objects
- Host: GitHub
- URL: https://github.com/r-lib/waldo
- Owner: r-lib
- License: other
- Created: 2020-03-29T16:00:40.000Z (almost 5 years ago)
- Default Branch: main
- Last Pushed: 2024-11-07T21:03:05.000Z (2 months ago)
- Last Synced: 2025-01-04T10:37:46.761Z (8 days ago)
- Topics: diff, r, testing
- Language: R
- Homepage: http://waldo.r-lib.org/
- Size: 2.56 MB
- Stars: 289
- Watchers: 5
- Forks: 20
- Open Issues: 5
-
Metadata Files:
- Readme: README.Rmd
- Changelog: NEWS.md
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
Awesome Lists containing this project
- jimsghstars - r-lib/waldo - Find differences between R objects (R)
README
---
output: github_document
always_allow_html: yes
editor_options:
chunk_output_type: console
---```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README",
out.width = "100%"
)
#
options(crayon.enabled = TRUE, crayon.colors = 256)
crayon::num_colors(forget = TRUE)
asciicast::init_knitr_engine(
startup = quote({
library(waldo)
conflicted::conflict_prefer("compare", "waldo")
}),
echo = TRUE,
echo_input = FALSE
)
set.seed(1014)
```# waldo
[![Codecov test coverage](https://codecov.io/gh/r-lib/waldo/branch/main/graph/badge.svg)](https://app.codecov.io/gh/r-lib/waldo?branch=main)
[![R-CMD-check](https://github.com/r-lib/waldo/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/r-lib/waldo/actions/workflows/R-CMD-check.yaml)The goal of waldo is to find and concisely describe the difference between a pair of R objects, with the primary goal of making it easier to figure out what's gone wrong in your unit tests.
`waldo::compare()` is inspired by `all.equal()`, but takes additional care to generate actionable insights by:
* Ordering the differences from most important to least important.
* Displaying the values of atomic vectors that are actually different.
* Carefully using colour to emphasise changes (while still being readable
when colour isn't available).
* Using R code (not a text description) to show where differences arise.
* Where possible, comparing elements by name, rather than by position.
* Erring on the side of producing too much output, rather than too little.## Installation
You can install the released version of waldo from [CRAN](https://CRAN.R-project.org) with:
``` r
install.packages("waldo")
```## Comparisons
```{r setup}
library(waldo)
```When comparing atomic vectors, `compare()` produces diffs (thanks to [diffobj](https://github.com/brodieG/diffobj)) that highlight additions, deletions, and changes, along with a little context:
* Deletion
```{asciicast}
compare(c("a", "b", "c"), c("a", "b"))
```* Addition
```{asciicast}
compare(c("a", "b"), c("a", "b", "c"))
```* Change
```{asciicast}
compare(c("a", "b", "c"), c("a", "B", "c"))
```* Long vectors with short differences only show local context around
changes, not everything that's the same.```{asciicast}
compare(c("X", letters), c(letters, "X"))
```Depending on the relative size of the differences and the width of your console you'll get one of three displays:
* The default display is to show the vectors one atop the other:
```{asciicast}
compare(letters[1:5], letters[1:6])
```* If there's not enough room for that, the two vectors are shown
side-by-side:```{asciicast}
options(width = 20)
compare(letters[1:5], letters[1:6])
```* And if there's still not enough room for side-by-side, the each element
is given its own line:```{asciicast}
options(width = 10)
compare(letters[1:5], letters[1:6])
```When comparing more complex objects, waldo creates an executable code path telling you where the differences lie:
```{asciicast, include = FALSE}
options(width = 80)
```* Unnamed lists are compared by position:
```{asciicast}
compare(list(factor("x")), list(1L))
```* Named lists, including data frames, are compared by name. For example,
note that the following comparison reports a difference in the class and
names, but not the values of the columns.```{asciicast}
df1 <- data.frame(x = 1:3, y = 3:1)
df2 <- tibble::tibble(rev(df1))
compare(df1, df2)
```* Recursion can be arbitrarily deep:
```{asciicast}
x <- list(a = list(b = list(c = list(structure(1, e = 1)))))
y <- list(a = list(b = list(c = list(structure(1, e = "a")))))
compare(x, y)
```