tests/testthat/test-mixed.R

# Tests the mixedTests function.
# library(csaw); library(testthat); source("test-mixed.R")

autogen <- function(n.clusters, total.n) {
    ids <- sample(n.clusters, total.n, replace=TRUE)
    tab <- data.frame(logFC=runif(total.n, -1, 1), logCPM=runif(total.n, -2, 1), PValue=rbeta(total.n, 1, 10))
    return(list(id=ids, table=tab))
}

set.seed(60000)
test_that("mixedTests works as expected on vanilla inputs", {
    for (ntests in c(10, 50, 100)) {
        test <- autogen(20, ntests)
        ids <- test$id
        tab <- test$table
        tabmix <- mixedTests(ids, tab)

        uptab <- tab
        uptab$PValue <- ifelse(tab$logFC > 0, tab$PValue/2, 1-tab$PValue/2)
        tabup <- combineTests(ids, uptab)

        downtab <- tab
        downtab$PValue <- ifelse(tab$logFC < 0, tab$PValue/2, 1-tab$PValue/2)
        tabdown <- combineTests(ids, downtab)

        expect_identical(tabmix[,1:2], tabup[,1:2])
        expect_identical(tabmix[,3], tabdown[,3])

        expect_identical(tabmix$rep.up.test, tabup$rep.test)
        expect_identical(tabmix$rep.down.test, tabdown$rep.test)
        expect_identical(tabmix$rep.up.logFC, tabup$rep.logFC)
        expect_identical(tabmix$rep.down.logFC, tabdown$rep.logFC)

        expect_identical(tabmix$PValue, pmax(tabup$PValue, tabdown$PValue))
        expect_identical(tabmix$FDR, p.adjust(tabmix$PValue, method="BH"))
    }
})

set.seed(60001)
test_that("mixedTests works as expected with weights", {
    for (ntests in c(10, 50, 100)) {
        test <- autogen(20, ntests)
        ids <- test$id
        tab <- test$table
        w <- runif(ntests)
        tabmix <- mixedTests(ids, tab, weight=w)

        uptab <- tab
        uptab$PValue <- ifelse(tab$logFC > 0, tab$PValue/2, 1-tab$PValue/2)
        tabup <- combineTests(ids, uptab, weight=w)

        downtab <- tab
        downtab$PValue <- ifelse(tab$logFC < 0, tab$PValue/2, 1-tab$PValue/2)
        tabdown <- combineTests(ids, downtab, weight=w)

        expect_identical(tabmix[,1:2], tabup[,1:2])
        expect_identical(tabmix[,3], tabdown[,3])
        expect_identical(tabmix$PValue, pmax(tabup$PValue, tabdown$PValue))
        expect_identical(tabmix$FDR, p.adjust(tabmix$PValue, method="BH"))
    }
})

set.seed(60002)
test_that("mixedTests works as expected with alternative options", {
    test <- autogen(20, 100)
    ids <- test$id
    tab <- test$table
    ref <- mixedTests(ids, tab)

    retab <- tab
    retab$whee <- tab$logFC
    retab$yay <- tab$PValue
    retab$logFC <- NULL
    retab$PValue <- NULL
    out <- mixedTests(ids, retab, fc.col="whee", pval.col="yay")
 
    expect_identical(out$num.up.whee, ref$num.up.logFC)
    expect_identical(out$num.down.whee, ref$num.down.logFC)
    expect_identical(out$yay, ref$PValue)
})

set.seed(60003) 
test_that("mixedTests behaves correctly with silly inputs", {
    test <- autogen(20, 100)
    ids <- test$id
    tab <- test$table
    ref <- mixedTests(ids[0], tab[0,])
    expect_identical(dim(ref), c(0L, 10L))

    expect_error(mixedTests(ids, tab[0,]), "not TRUE")
    expect_error(mixedTests(ids, tab, weight=0), "not TRUE")
})
LTLA/csaw documentation built on Dec. 11, 2023, 5:11 a.m.