tests/test-rdiff.R

NAME <- "rdiff"
source(file.path('_helper', 'init.R'))

# - diff util detection --------------------------------------------------------

identical(has_Rdiff(function(...) warning("test warning")), FALSE)
isTRUE(has_Rdiff(function(...) NULL))

# - errors ---------------------------------------------------------------------

try(Rdiff_chr(stop('hello'), 'goodbye')) # "Unable to coerce"
try(Rdiff_chr('hello', stop('goodbye'))) #  "Unable to coerce"
try(Rdiff_obj(stop('hello'), 'goodbye')) #  "Unable to store"

# - Rdiff_chr/obj --------------------------------------------------------------

# Only run tests on machines that are likely to have diff utility

if(identical(.Platform$OS.type, "unix") && has_Rdiff()) {
  local({
    A2 <- c("A", "B", "C")
    B2 <- c("X", "A", "Y", "C")
    A3 <- 1:3
    B3 <- c(100L, 1L, 200L, 3L)

    # Rdiff_chr

    ref.res <- c("0a1", "2c3")
    ref.res.1 <- c("0a1", "> X", "2c3", "< B", "---", "> Y")

    a <- identical(Rdiff_chr(A2, B2, silent=TRUE, minimal=TRUE), ref.res)
    capt <- capture.output(res <- Rdiff_chr(A2, B2, silent=FALSE, minimal=TRUE))
    b <- identical(res, ref.res)
    c <- identical(capt, res)
    capt.1 <- capture.output(
      res.1 <- Rdiff_chr(A2, B2, silent=FALSE, minimal=FALSE)
    )
    d <- identical(capt.1, ref.res.1)
    e <- identical(res.1, ref.res.1)

    # test coersion
    f <- identical(Rdiff_chr(A3, B3, minimal=TRUE, silent=TRUE), ref.res)

    # Rdiff_obj

    ref.res2 <- c("1c1", "< [1] \"A\" \"B\" \"C\"", "---", "> [1] \"X\" \"A\" \"Y\" \"C\"" )
    ref.res3 <- c("1c1")

    g <- identical(Rdiff_obj(A2, B2, silent=TRUE), ref.res2)
    h <- identical(Rdiff_obj(A2, B2, minimal=TRUE, silent=TRUE), ref.res3)

    # with rds
    f1 <- tempfile()
    f2 <- tempfile()
    saveRDS(A2, f1)
    saveRDS(B2, f2)
    on.exit(unlink(c(f1, f2)))

    i <- identical(Rdiff_obj(f1, B2, silent=TRUE), ref.res2)
    j <- identical(Rdiff_obj(A2, f2, silent=TRUE), ref.res2)
    k <- identical(Rdiff_obj(f1, f2, silent=TRUE), ref.res2)

    res <- c(a, b, c, d, e, f, g, h, i, k)
    if(!all(res)) stop("Failed: ", deparse(which(!res)))
  })
}

Try the diffobj package in your browser

Any scripts or data that you put into this service are public.

diffobj documentation built on Oct. 5, 2021, 9:07 a.m.