longtests/testthat/test-scanpy_trajectory.R

library(SingleCellExperiment)
library(BiocFileCache)

cache <- BiocFileCache(ask = FALSE)
file <- bfcrpath(cache, "https://figshare.com/ndownloader/files/30594477")
outfile <- tempfile(fileext = ".h5ad")

names <- list(
    assays = c("X"),
    colData = c("paul15_clusters", "n_counts_all", "louvain", "dpt_pseudotime"),
    rowData = c("n_counts", "mean", "std"),
    metadata = c("diffmap_evals", "draw_graph", "iroot", "louvain",
                 "louvain_sizes", "neighbors", "paga", "pca"),
    redDim = c("X_diffmap", "X_draw_graph_fa", "X_pca"),
    varm = c("PCs"),
    colPairs = c("connectivities", "distances")
)

missing <- list()

test_that("Reading H5AD works", {
    sce <- readH5AD(file)
    expect_s4_class(sce, "SingleCellExperiment")
})

sce <- suppressWarnings(readH5AD(file))

test_that("SCE is valid", {
    validateH5ADSCE(sce, names, missing)
})

test_that("Writing H5AD works", {
    writeH5AD(sce, outfile)
    expect_true(file.exists(outfile))
})

test_that("Round trip is as expected", {
    out <- readH5AD(outfile)
    expectSCE(out, sce)
})
theislab/zellkonverter documentation built on Oct. 24, 2024, 7:43 a.m.