inst/tinytest/test_nse.R

library(lumberjack)

## NSE helper functions
# symbol replacement
  
  expect_identical(
    lumberjack:::replace(expression(x + y)[[1]],quote(x),quote(z))
    , expression(z + y)[[1]])
  
  expect_identical(
    lumberjack:::replace(expression(x + y*y)[[1]],quote(y),quote(z))
    , expression(x + z*z)[[1]])

  expect_identical(
    lumberjack:::replace(expression(x + f(y*y))[[1]],quote(y),quote(z))
    , expression(x + f(z*z))[[1]])


## The pipe

expect_identical(1:3 %>>% mean(), mean(1:3))
expect_identical(1:3 %>>% mean(na.rm=TRUE), mean(1:3, na.rm=TRUE))
expect_identical(1:3 %>>% mean(.), 2)
expect_identical(1:3 %>>% mean(.,na.rm=TRUE), 2)
g <- 1:3
expect_identical(g %>>% mean(), mean(g))

expect_identical( 3 %>>% {2 * .}, 6)
expect_identical( 3 %>>% (2 * .), 6)  
expect_identical(
  mean(c(1,NA,3),na.rm=TRUE)
  , TRUE %>>% mean(c(1,NA,3),na.rm=.)
  
)
  
expect_equal(
  coefficients(lm(height ~ weight,data=women)) 
  , women %>>% lm(height ~ weight, data=.) %>>% coefficients()
)

Try the lumberjack package in your browser

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

lumberjack documentation built on March 31, 2023, 7:56 p.m.