tests/testthat/test_groupable.R

# library(testthat); library(iSEE); source("test_groupable.R")

context("groupable")

test_that("grouping evaluation functions work correctly", {
    X <- data.frame(A=LETTERS[1:10], B=1L, C=0.1, D=factor(letters[1:10]))
    expect_equivalent(iSEE:::.whichGroupable(X), c(1L, 4L))
    expect_equivalent(iSEE:::.whichNumeric(X), c(2L, 3L))

    # Too many levels to consider groupable.
    X <- data.frame(A=LETTERS, B=1L)
    expect_equivalent(iSEE:::.whichGroupable(X), 1L)
    expect_equivalent(iSEE:::.whichGroupable(X, max_levels=20), integer(0))
    expect_equivalent(iSEE:::.whichNumeric(X), 2L)
})

test_that("grouping functions are robust in the absence of columns", {
    out <- iSEE:::.whichNumeric(DataFrame())
    expect_equivalent(out, integer(0L))

    out <- iSEE:::.whichGroupable(DataFrame())
    expect_equivalent(out, integer(0L))
})

test_that("finding atomic fields works correctly", {
    X <- DataFrame(A=LETTERS[1:10], B=1L, C=0.1, D=factor(letters[1:10]))
    expect_identical(iSEE:::.findAtomicFields(X), colnames(X))

    X <- DataFrame(A=Rle(1:5), B=2)
    expect_identical(iSEE:::.findAtomicFields(X), "B")
})
csoneson/iSEE documentation built on Dec. 13, 2024, 6:14 a.m.