tests/testthat/test_utils.R

# library(iSEE); library(testthat); source("setup_sce.R"); source("test_utils.R")

# utils_colors.R ----
context("Color utilities")

test_that(".getPanelColor returns the expected colors", {

    x <- ColumnDataPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#DB0230")

    x <- ColumnDataTable()
    out <- .getPanelColor(x)
    expect_identical(out, "#B00258")

    x <- ComplexHeatmapPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#440154FF")

    x <- FeatureAssayPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#7BB854")

    x <- ReducedDimensionPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#3565AA")

    x <- RowDataPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#F2B701")

    x <- RowDataTable()
    out <- .getPanelColor(x)
    expect_identical(out, "#E47E04")

    x <- SampleAssayPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#07A274")

    iSEEOptions$set(panel.color=c(ReducedDimensionPlot="#1e90ff"))

    x <- ReducedDimensionPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#1e90ff")

    iSEEOptions$restore()

    x <- ReducedDimensionPlot()
    out <- .getPanelColor(x)
    expect_identical(out, "#3565AA")

})

test_that(".define_box_statuses generates the CSS classes for each box", {

    out <- iSEE:::.define_box_statuses(list(ReducedDimensionPlot(), FeatureAssayPlot()))
    expect_match(out, "reduceddimensionplot")
    expect_match(out, .panelColor(ReducedDimensionPlot()))

    expect_match(out, "featureassayplot")
    expect_match(out, .panelColor(FeatureAssayPlot()))

})

# utils_class.R ----
context("Class utilities")

test_that(".singleStringError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.colorByField]] <- character(0), 
        "'ColorBy' should be a single string for 'ReducedDimensionPlot'")
})

test_that(".validLogicalError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.visualParamBoxOpen]] <- NA,
        "'VisualBoxOpen' should be a non-NA logical scalar")
})

test_that(".validStringError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.colorByDefaultColor]] <- c("a", "b"),
        "'ColorByDefaultColor' should be a non-NA string") 
})

test_that(".allowableChoiceError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.colorByField]] <- "other",
        "'ColorBy' for 'ReducedDimensionPlot' should be one") 
})

test_that(".multipleChoiceError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.visualParamChoice]] <- "other",
        "values of 'VisualChoices' for 'ReducedDimensionPlot' should be")
})

test_that(".validNumberError detects issues", {

    msg <- character(0)

    x <- ReducedDimensionPlot()
    expect_error(x[[iSEE:::.selectTransAlpha]] <- 2,
        "'SelectionAlpha' for 'ReducedDimensionPlot' should be a numeric scalar")
})

# utils_reactive.R ----
context("Reactive utilities")

test_that(".retrieveOutput detects cached panels", {

    pObjects <- new.env()
    rObjects <- new.env()

    cachedInfo <- list(
        commands = c("ggplot()"),
        contents = data.frame()
    )

    pObjects$cached <- list(ReducedDimensionPlot1=cachedInfo)

    out <- .retrieveOutput("ReducedDimensionPlot1", sce, pObjects, rObjects)
    expect_identical(out, cachedInfo)
    expect_identical(out$commands, cachedInfo$commands)
    expect_identical(out$contents, cachedInfo$contents)

})

test_that(".requestUpdate updates rObjects", {

    rObjects <- new.env()
    rObjects$modified <- list()

    .requestUpdate("ReducedDimensionPlot1", rObjects)

    expect_identical(rObjects$modified, list(ReducedDimensionPlot1 = character(0)))
})

test_that(".requestCleanUpdate updates rObjects", {

    pObjects <- new.env()
    pObjects$memory <- list()
    rObjects <- new.env()

    x <- ReducedDimensionPlot()
    x[[iSEE:::.brushData]] <- list(xmin=1, xmax=2, ymin=1, ymax=2)
    x[[iSEE:::.multiSelectHistory]] <- list(list(xmin=1, xmax=2, ymin=1, ymax=2))
    pObjects$memory <- list(ReducedDimensionPlot1=x)

    .requestCleanUpdate("ReducedDimensionPlot1", pObjects, rObjects)

    expect_identical(pObjects$memory$ReducedDimensionPlot1[[iSEE:::.brushData]], list())
    expect_identical(pObjects$memory$ReducedDimensionPlot1[[iSEE:::.multiSelectHistory]], list())
})

test_that(".requestActiveSelectionUpdate updates rObjects", {

    rObjects <- new.env()
    rObjects$modified <- list()
    pObjects <- new.env()
    pObjects$memory <- list(ReducedDimensionPlot1=ReducedDimensionPlot())
    
    .requestActiveSelectionUpdate("ReducedDimensionPlot1", session=NULL, pObjects, rObjects, update_output = TRUE)

    expect_identical(rObjects$ReducedDimensionPlot1_INTERNAL_multi_select, 2L)
    expect_identical(rObjects$modified, list(ReducedDimensionPlot1 = "Reactivated"))

    .requestActiveSelectionUpdate("ReducedDimensionPlot1", session=NULL, pObjects, rObjects, update_output = FALSE)

    expect_identical(rObjects$ReducedDimensionPlot1_INTERNAL_multi_select, 3L)
    expect_identical(rObjects$modified, list(ReducedDimensionPlot1 = c("Reactivated", "Norender")))
})

test_that(".trackSingleSelection forces evaluation of .flagSingleSelect", {

    rObjects <- new.env()

    panel_name <- "ReducedDimensionPlot1"
    rObjects[[paste0(panel_name, "_", iSEE:::.flagSingleSelect)]] <- "forced output"

    out <- .trackSingleSelection("ReducedDimensionPlot1", rObjects)
    expect_identical(out, "forced output")
})

test_that(".trackMultiSelection forces evaluation of .flagMultiSelect", {

    rObjects <- new.env()

    panel_name <- "ReducedDimensionPlot1"
    rObjects[[paste0(panel_name, "_", iSEE:::.flagMultiSelect)]] <- "forced output"

    out <- .trackMultiSelection("ReducedDimensionPlot1", rObjects)
    expect_identical(out, "forced output")
})

test_that(".trackRelinkedSelection forces evaluation of .flagRelinkedSelect", {

    rObjects <- new.env()

    panel_name <- "ReducedDimensionPlot1"
    rObjects[[paste0(panel_name, "_", iSEE:::.flagRelinkedSelect)]] <- "forced output"

    out <- .trackRelinkedSelection("ReducedDimensionPlot1", rObjects)
    expect_identical(out, "forced output")
})

test_that(".safe_reactive_bump reset counter to 0 at a threhsold", {

    rObjects <- new.env()
    rObjects$counter <- 8L

    iSEE:::.safe_reactive_bump(rObjects, "counter", 10L)
    expect_identical(rObjects$counter, 9L)

    iSEE:::.safe_reactive_bump(rObjects, "counter", 10L)
    expect_identical(rObjects$counter, 0L)

})

test_that(".increment_counter works", {

    counter <- 8L

    out <- iSEE:::.increment_counter(counter, max = 10L)
    expect_identical(out, 9L)

    out <- iSEE:::.increment_counter(counter, max = 9L)
    expect_identical(out, 0L)

})

test_that(".safe_nonzero_range works", {

    out <- iSEE:::.safe_nonzero_range(range = c(3, 4), centered = FALSE)
    expect_identical(out, c(3, 4))

    out <- iSEE:::.safe_nonzero_range(range = c(2, 2), centered = FALSE)
    expect_identical(out, c(2, 3))

    out <- iSEE:::.safe_nonzero_range(range = c(2, 2), centered = TRUE)
    expect_identical(out, c(1, 3))

})

test_that(".gather_current_memory works as expected", {

    input <- list()
    input[[iSEE:::.generalMemoryIncludeSE]] <- TRUE
    input[[iSEE:::.generalMemoryIncludeECM]] <- TRUE

    pObjects <- new.env()
    pObjects$memory <- list("YAY")

    metadata(sce)$colormap <- "WHEE"

    out <- iSEE:::.gather_current_memory(sce, input, pObjects)

    expect_identical(out$se, sce)
    expect_identical(out$memory, pObjects$memory)
    expect_identical(out$colormap, "WHEE")

})

test_that(".removeInvalidChoices removes invalid choices", {
    x <- ColumnDataPlot(
        TooltipColumnData = "bad_name"
    )
    
    expect_warning(
        out <- iSEE:::.removeInvalidChoices(x, iSEE:::.tooltipColData, colnames(colData(sce))),
        "Removing invalid values"
    )
    expect_identical(out[[iSEE:::.tooltipColData]], character(0))
})
csoneson/SEE documentation built on Oct. 13, 2024, 10:19 a.m.