inst/tinytest/testPiecemeal.R

# Test piecemeal addition, export, and retrieval

# Setup ------------------------------------------------------------------------

source("tinytestSettings.R")
using(ttdo)

library(OmicNavigator)

tmplib <- tempfile()
dir.create(tmplib)
libOrig <- .libPaths()
.libPaths(c(tmplib, libOrig))

study <- createStudy(name = "test")

# Test results only ------------------------------------------------------------

results <- OmicNavigator:::testResults()
study <- addResults(study, results = results)

suppressMessages(installStudy(study))

testModelName <- names(study[["results"]])[1]
testTestName <- names(study[["results"]][[1]])[1]

expect_equal_xl(
  getResultsTable(study$name, testModelName, testTestName),
  getResults(study$name, testModelName, testTestName)
)

expect_identical_xl(
  getEnrichmentsTable(study$name, testModelName, "non-existent-annotation"),
  data.frame()
)

expect_identical_xl(
  getEnrichmentsNetwork(study$name, testModelName, "non-existent-annotation"),
  list()
)

expect_identical_xl(
  getNodeFeatures(study$name, "non-existent-annotation", "non-existent-term"),
  character()
)

expect_identical_xl(
  getLinkFeatures(study$name, "non-existent-annotation", "non-existent-term-1", "non-existent-term-2"),
  character()
)

resultsIntersection <- getResultsIntersection(
  study$name,
  testModelName,
  testTestName,
  mustTests = c(),
  notTests = c(),
  sigValue = 0.05,
  operator = "<",
  column = "beta"
)

expect_true_xl(nrow(resultsIntersection) > 0)
expect_true_xl(ncol(resultsIntersection) > 0)

expect_identical_xl(
  colnames(resultsIntersection)[2],
  "Set_Membership"
)

expect_identical_xl(
  getMetaFeaturesTable(study$name, testModelName, "non-existent-feature"),
  data.frame()
)

expect_identical_xl(
  getBarcodeData(study$name, testModelName, testTestName, "non-existent-annotation", "non-existent-term"),
  list()
)

expect_identical_xl(
  getReportLink(study, testModelName),
  character()
)

# Test models and tests --------------------------------------------------------

models <- OmicNavigator:::testModels()
# Confirm a message is emitted and empty list returned when only some models
# have a description available.
study <- addModels(study, models = models[1])
expect_message_xl(
  modelReturnObject <- getModels(study, modelID = names(models)[2]),
  names(models)[2]
)
expect_identical_xl(
  modelReturnObject,
  list()
)

study <- addModels(study, models = models)
tests <- OmicNavigator:::testTests()
study <- addTests(study, tests = tests)

suppressMessages(
  exportStudy(study, type = "package", path = tmplib)
)

# Test features, samples, and assays -------------------------------------------

features <- OmicNavigator:::testFeatures()
study <- addFeatures(study, features = features)

samples <- OmicNavigator:::testSamples()
study <- addSamples(study, samples = samples)

assays <- OmicNavigator:::testAssays()
study <- addAssays(study, assays = assays)

suppressMessages(
  exportStudy(study, type = "package", path = tmplib)
)

# Test enrichments -------------------------------------------------------------

enrichments <- OmicNavigator:::testEnrichments()
study <- addEnrichments(study, enrichments = enrichments)

suppressMessages(installStudy(study))

testAnnotationName <- names(study[["enrichments"]][[1]])[1]

enrichmentsTable <- getEnrichmentsTable(study$name, testModelName, testAnnotationName)
expect_true_xl(nrow(enrichmentsTable) > 0)
expect_true_xl(ncol(enrichmentsTable) > 0)

expect_identical_xl(
  getEnrichmentsNetwork(study$name, testModelName, testAnnotationName),
  list()
)

expect_identical_xl(
  getNodeFeatures(study$name, testAnnotationName, "non-existent-term"),
  character()
)

expect_identical_xl(
  getLinkFeatures(study$name, testAnnotationName, "non-existent-term-1", "non-existent-term-2"),
  character()
)

enrichmentsIntersection <- getEnrichmentsIntersection(
  study = study$name,
  modelID = testModelName,
  annotationID = testAnnotationName,
  mustTests = c(),
  notTests = c(),
  sigValue = 0.05,
  operator = "<",
  type = "nominal"
)
expect_true_xl(nrow(enrichmentsIntersection) > 0)
expect_true_xl(ncol(enrichmentsIntersection) > 0)

# Test annotations -------------------------------------------------------------

expect_warning_xl(
  addOverlaps(study),
  "Cannot calculate overlaps without annotations"
)

annotations <- OmicNavigator:::testAnnotations()
study <- addAnnotations(study, annotations = annotations)

suppressMessages(
  exportStudy(study, type = "package", path = tmplib)
)

# Teardown ---------------------------------------------------------------------

unlink(tmplib, recursive = TRUE, force = TRUE)
.libPaths(libOrig)
abbvie-external/OmicNavigator documentation built on April 12, 2025, 12:07 a.m.