test_that("CompDbSource works", {
expect_error(new("CompDbSource", dbfile = tempfile()), "unable")
fl <- system.file("extdata", "MS1_example.txt", package = "MetaboAnnotation")
expect_error(new("CompDbSource", dbfile = fl), "database")
res <- new("CompDbSource")
expect_true(validObject(res))
fl <- system.file("sql", "CompDb.MassBank.sql", package = "CompoundDb")
res <- new("CompDbSource", dbfile = fl)
expect_true(validObject(res))
expect_true(.validate_dbfile(fl))
expect_output(show(res), "CompDbSource")
})
test_that("metadata,CompDbSource works", {
fl <- system.file("sql", "CompDb.MassBank.sql", package = "CompoundDb")
src <- new("CompDbSource", dbfile = fl)
res <- metadata(src)
expect_true(is.data.frame(res))
})
test_that("matchSpectra,Spectra,CompDbSource works", {
fl <- system.file("sql", "CompDb.MassBank.sql", package = "CompoundDb")
src <- new("CompDbSource", dbfile = fl)
res <- matchSpectra(pest_ms2, src, param = CompareSpectraParam(),
addOriginalQueryIndex = FALSE)
expect_s4_class(res, "MatchedSpectra")
expect_equal(query(res), pest_ms2)
expect_s4_class(target(res)@backend, "MsBackendDataFrame")
expect_true(length(target(res)) == 0)
library(CompoundDb)
library(BiocParallel)
register(SerialParam())
if (file.exists(fl)) {
qry <- Spectra(CompoundDb::CompDb(fl))[3]
res <- matchSpectra(qry, src, param = CompareSpectraParam())
expect_true(length(target(res)) == 4)
expect_equal(MetaboAnnotation::matches(res)$target_idx, 1:4)
expect_s4_class(target(res)@backend, "MsBackendDataFrame")
}
})
test_that("MassBankSource works with AnnotationHub", {
if (requireNamespace("AnnotationHub", quietly = TRUE)) {
expect_error(MassBankSource(release = "other"), "not found")
expect_error(MassBankSource(release = ""), "ambiguous")
mb <- MassBankSource("2021.03")
expect_s4_class(mb, "CompDbSource")
expect_true(length(mb@dbfile) == 1L)
}
with_mocked_bindings(
".is_available_annotation_hub" = function() FALSE,
code = expect_error(MassBankSource(), "requires")
)
})
test_that(".is_available_annotation_hub works", {
expect_true(.is_available_annotation_hub())
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.