# This tests the perCellQCFilters function.
# library(testthat); library(scuttle); source("setup.R"); source("test-qc-filters.R")
original <- sce
test_that("perCellQCFilters works correctly", {
df <- perCellQCMetrics(original)
df$sum[1] <- 0
df$detected[2] <- 0
out <- perCellQCFilters(df)
expect_true(out$low_lib_size[1])
expect_true(out$low_n_features[2])
expect_identical(out$discard, out$low_lib_size | out$low_n_features)
})
test_that("perCellQCFilters works correctly with subsets", {
df <- perCellQCMetrics(original)
df$subsets_BLAH_percent <- c(1, rep(0, nrow(df)-1))
df$altexps_WHEE_percent <- c(0, 1, rep(0, nrow(df)-2))
df$sum[3] <- 0
df$detected[4] <- 0
out <- perCellQCFilters(df, sub.fields=c("subsets_BLAH_percent", "altexps_WHEE_percent"))
expect_true(out$high_subsets_BLAH_percent[1])
expect_true(out$high_altexps_WHEE_percent[2])
expect_identical(out$discard, Reduce("|", out[,1:4]))
out2 <- perCellQCFilters(df, sub.fields=TRUE)
expect_identical(out, out2)
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.