tests/testthat/test_setwrapper_powersetset.R

library(testthat)

context("PowersetSet")

test_that("Set", {
  expect_equal(getR6Class(powerset(Set$new(1, 2), FALSE)), "PowersetSet")
  expect_equal(powerset(Set$new(1, 2), FALSE)$strprint(), paste0("\U2118(", "{1, 2}", ")"))
  useUnicode(FALSE)
  expect_equal(powerset(Set$new(1, 2), FALSE)$strprint(), "2^{1, 2}")
  useUnicode(TRUE)
})

test_that("contains Set", {
  ps <- powerset(Set$new(1, 2, 3, 5))
  expect_true(ps$contains(Set$new(1, 2)))
  expect_false(Set$new(2, 8) %inset% ps)
  expect_true(ps$contains(Set$new(1, 2), Set$new(3, 5), all = TRUE))
})

test_that("contains Interval", {
  ps <- powerset(Interval$new(1, 5))
  expect_true(ps$contains(Interval$new(2, 4)))
  expect_false(ps$contains(Interval$new(2, 8)))
})

test_that("isSubset", {
  ps <- powerset(Set$new(1, 2, 3, 5))
  expect_false(ps$isSubset(1))
  expect_true(ps <= ps)
  expect_false(ps < ps)
  expect_false(Set$new(1) < ps)
  expect_true(Set$new(Set$new(1)) < ps)
  expect_true(powerset(Set$new(1, 2)) < ps)
  expect_false(FuzzySet$new(1, 1) < ps)
})

test_that("isSubset Interval", {
  ps <- powerset(Interval$new(1, 5))
  expect_true(ps$isSubset(Set$new(Interval$new(2, 4))))
  expect_false(ps$isSubset(Set$new(Interval$new(2, 8))))
})

test_that("cardinality", {
  expect_equal(powerset(Set$new(1, 2, 3))$properties$cardinality, 8)
  expect_equal(powerset(Integers$new())$properties$cardinality, "Beth1")
  expect_equal(powerset(Reals$new())$properties$cardinality, "Beth2")
  expect_equal(powerset(powerset(Integers$new()))$properties$cardinality, "Beth2")
  expect_equal(powerset(powerset(powerset(Integers$new())))$properties$cardinality, "Beth3")
})

Try the set6 package in your browser

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

set6 documentation built on Oct. 18, 2021, 5:06 p.m.