tests/testthat/test-in_detect.R

expect_same_behavior <- function(object, expected, ...) {
  object_chr   <- deparse(substitute(object))
  expected_chr <- deparse(substitute(expected))
  quiet        <- purrr::safely(purrr::quietly(identity))
  object       <- eval(substitute(quiet(object)))
  expected     <- eval(substitute(quiet(expected)))
  testthat::expect(
    identical(object$result$result, expected$result$result, ...),
    sprintf("`%s` and `%s` don't return the same result.", object_chr, expected_chr))
  testthat::expect(
    identical(object$result$output, expected$result$output, ...),
    sprintf("`%s` and `%s` don't print the same output", object_chr, expected_chr))
  testthat::expect(
    identical(object$result$messages, expected$result$messages, ...),
    sprintf("`%s` and `%s` don't print the same messages", object_chr, expected_chr))
  testthat::expect(
    identical(object$result$warnings, expected$result$warnings, ...),
    sprintf("`%s` and `%s` don't trigger the same warnings", object_chr, expected_chr))
  testthat::expect(
    identical(object$error$message, expected$error$message, ...),
    sprintf("`%s` and `%s` don't trigger the same error", object_chr, expected_chr))
  invisible(NULL)
}

test_that("%out% works", expect_true(3 %out% 1:2))
test_that("%out{}% works", expect_true(3 %out{}% 1:2))
test_that("%out()% works", expect_true(3 %out()% 1:2))
test_that("%out[)% works", expect_true(3 %out[)% 1:2))
test_that("%out(]% works", expect_true(3 %out(]% 1:2))
test_that("%out[]% works", expect_true(3 %out[]% 1:2))
test_that("%out# works", expect_true(3 %out#% 2:3))

test_that("%in{}% works with factors", expect_true("a" %in{}% factor(c("a","b"))))
test_that("%in{}% works with matrices", {
  expect_identical(matrix(letters[1:4],2) %in{}% c("a","b"),
                   matrix(c(T,T,F,F),2))
})
test_that("%in{}% works with language", {
  expect_true("a" %in{}% quote(a))
  expect_true(quote(a) %in{}% c(quote(a), quote(b)))
  expect_true(quote(a+b) %in{}% c(quote(a+b), quote(b)))
  expect_true(quote(a+b) %in{}% quote(a+b))
  expect_identical(c(quote(a), quote(b)) %in{}% quote(a), c(T,F))
})

test_that("range ops work with lists", {
  expect_true(1 %in()% list(0,3))
  expect_false(0 %in()% list(0,3))
  expect_false(3 %in()% list(0,3))
  expect_true(1 %in(]% list(0,1))
  expect_false(0 %in(]% list(0,3))
  expect_true(1 %in[)% list(1,3))
  expect_false(3 %in[)% list(1,3))
  expect_true(1 %in[]% list(1,3))
  expect_true(3 %in[]% list(1,3))
})

test_that("regex ops work", {
  expect_true("abababa" %in~% "^ab")
  expect_true("abababa" %in~p% "^ab")
  expect_true("a.ababa" %in~f% "a.")
  expect_false("abababa" %out~% "^ab")
  expect_false("abababa" %out~p% "^ab")
  expect_false("a.ababa" %out~f% "a.")
})

test_that("regex ops work with lists", {
  expect_true(list("abababa") %in~% "^ab")
})

test_that("regex ops work with matrices", {
  expect_identical(matrix(c("abababa","c","d","e"),2) %in~% "^ab",
                   matrix(c(T,F,F,F),2))
})

test_that("regex ops work with factors", {
  expect_true("a" %in~% factor("a"))
expect_true(factor("a") %in~% "a")
expect_true(factor("a") %in~% factor("a"))
})

test_that("count ops work", {
  expect_equal(c(1,1,2,3,4,4) %in#% 2, c(TRUE,TRUE,FALSE,FALSE,TRUE,TRUE))
  expect_equal(c(1,1,2,3,4,4) %out#% 2, c(FALSE,FALSE,TRUE,TRUE,FALSE,FALSE))
})

test_that("count ops work with matrices", {
  expect_identical(matrix(c(1,2,3,1),2) %in#% 2,
                   matrix(c(T,F,F,T),2))
})

test_that("count ops work with factors", {
  expect_equal(factor(c("a", "b", "a")) %in#% 2, c(TRUE, FALSE, TRUE))
})

context("consistency of check ops with equality/comparison ops")

test_chr <- c(names(iris), NA)
test_num <- c(1:5,NA)
test_list1 <- c(as.list(c(1:5,NA)),
                as.list(c(letters[1:5], NA)),
                as.list(factor(c(letters[1:5], NA))))
test_list2 <- list(1:3, c(4:5,NA) ,
                   letters[1:3], c(letters[4:5], NA),
                   factor(c(letters[1:5], NA)))
test_df <- data.frame(
  a = 1:3, b = c(4:5,NA), c = letters[1:3], d = c(letters[4:5], NA),
  e = factor(letters[1:3]), f = factor(c(letters[4:5], NA)),stringsAsFactors = FALSE)

test_that("`%in{}%` is consistent with `==`",{
  expect_same_behavior(test_chr == "Petal.Length", test_chr %in{}% "Petal.Length")
  expect_same_behavior(test_num == 3, test_num %in{}% 3)
  expect_same_behavior(test_list1 == 3, test_list1 %in{}% 3)
  expect_same_behavior(test_list2 == 3, test_list2 %in{}% 3)
  expect_same_behavior(test_df == 3, test_df %in{}% 3)

  expect_same_behavior(
    test_chr == "Petal.Length" | test_chr == "Sepal.Length",
    test_chr %in{}% c("Petal.Length", "Sepal.Length"))
  expect_same_behavior(
    test_num == 3 | test_num == 4,
    test_num %in{}% c(3,4))
  expect_warning(test_list1 %in{}% c(3,4))
  expect_same_behavior(test_list2 == 3 | test_list2 == 4, test_list2 %in{}% 3)
  expect_same_behavior(test_df == 3 | test_df == 4, test_df %in{}% c(3,4))
})

test_that("`%in[]%` is consistent with `>=` and `<=`",{
  expect_same_behavior(
    test_num >= 2.5 & test_num <= 4.5,
    test_num %in[]% c(2.5,4.5))
  expect_same_behavior(
    test_list1 >= 2.5 & test_list1 <= 4.5,
    test_list1 %in[]% c(2.5,4.5))
  expect_same_behavior(test_list2 >= 2.5 & test_list2 <= 4.5, test_list2 %in[]% c(2.5,4.5))
  expect_same_behavior(test_df >= 2.5 & test_df <= 4.5, test_df %in[]% c(2.5,4.5))
})

test_that("`%in[)%` is consistent with `>=` and `<`",{
  expect_same_behavior(
    test_num >= 2.5 & test_num < 4.5,
    test_num %in[)% c(2.5,4.5))
  expect_same_behavior(
    test_list1 >= 2.5 & test_list1 < 4.5,
    test_list1 %in[)% c(2.5,4.5))
  expect_same_behavior(test_list2 >= 2.5 & test_list2 < 4.5, test_list2 %in[)% c(2.5,4.5))
  expect_same_behavior(test_df >= 2.5 & test_df < 4.5, test_df %in[)% c(2.5,4.5))
})

test_that("`%in(]%` is consistent with `>` and `<=`",{
  expect_same_behavior(
    test_num > 2.5 & test_num <= 4.5,
    test_num %in(]% c(2.5,4.5))
  expect_same_behavior(
    test_list1 > 2.5 & test_list1 <= 4.5,
    test_list1 %in(]% c(2.5,4.5))
  expect_same_behavior(test_list2 > 2.5 & test_list2 <= 4.5, test_list2 %in(]% c(2.5,4.5))
  expect_same_behavior(test_df > 2.5 & test_df <= 4.5, test_df %in(]% c(2.5,4.5))
})

test_that("`%in()%` is consistent with `>` and `<`",{
  expect_same_behavior(
    test_num > 2.5 & test_num < 4.5,
    test_num %in()% c(2.5,4.5))
  expect_same_behavior(
    test_list1 > 2.5 & test_list1 < 4.5,
    test_list1 %in()% c(2.5,4.5))
  expect_same_behavior(test_list2 > 2.5 & test_list2 < 4.5, test_list2 %in()% c(2.5,4.5))
  expect_same_behavior(test_df > 2.5 & test_df < 4.5, test_df %in()% c(2.5,4.5))
})

Try the inops package in your browser

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

inops documentation built on Nov. 19, 2019, 5:08 p.m.