tests/testthat/test_setoptsMC.R

i <- c(1, 1:9)
j <- 1:10

test_that("setdiffMC produces a List as expected", {
  ## Return a CharacterList
  cl <- .returnListColumn(letters[j], i, .simplify = FALSE)
  expect_equal(length(cl), max(i))
  expect_equal(length(cl[[1]]), 2)
  expect_true(is(cl, "CompressedCharacterList"))
})

test_that("setdiffMC handles List input", {
  x <- as(as.list(letters[j]), "CompressedCharacterList")
  x[[1]] <- c(x[[1]], "z")
  cl <- .returnListColumn(x, i, .simplify = TRUE)
  expect_equal(length(cl[[1]]), 3)
  expect_true(is(cl, "CompressedCharacterList"))
})

test_that("setdiffMC doesn't return a list when not expected", {
  cv <- .returnListColumn(letters[1:10], 1:10, .simplify = TRUE)
  expect_true(is(cv, "character"))
  expect_equal(length(cv), 10)
})

test_that(".mapMcols2Ranges returns empty mcols when required", {
  x <- GRanges("chr1:1-10")
  y <- GRanges("chr1:5")
  sd <- .mapMcols2Ranges(x, y, TRUE, TRUE)
  expect_equal(
    mcols(sd),
    new(
      "DFrame", rownames = NULL, nrows = 1L,
      listData = structure(list(), .Names = character(0)),
      elementType = "ANY", elementMetadata = NULL, metadata = list()
    )
  )
})

test_that("reduceMC returns a list when expected", {

  x <- GRanges(c("chr1:1-10:+", "chr1:6-12:-"))
  x$id <- c("range1", "range2")
  id <- reduceMC(x, ignore.strand = TRUE)$id
  expect_true(is(id, "CompressedCharacterList"))
  expect_equal(id[[1]], c("range1", "range2"))

  id <- reduceMC(x, ignore.strand = FALSE)$id
  expect_equal(id, c("range1", "range2"))
  expect_error(reduceMC(""), "'x' must be a GenomicRanges object")

})

test_that("empty ranges are returned when expected", {
  x <- GRanges(c("chr1:1-10:+", "chr1:6-12:-"))
  x$id <- c("range1", "range2")
  expect_equal(
    .mapMcols2Ranges(GRanges(), x, FALSE, TRUE),
    GRanges()
  )
})

test_that("unionMC works correctly", {
  x <- GRanges("chr1:1-100:+")
  x$id <- "range1"
  y <- GRanges(c("chr1:51-60:+", "chr1:21-30:-"))
  expect_equal(
    unionMC(x, y)$id, c("range1", NA_character_)
  )
  x$id <- CharacterList("range1")
  expect_equal(
    unionMC(x, y)$id,
    CharacterList("range1", character())
  )
})

test_that("intersectMC works correctly", {
    x <- GRanges("chr1:1-100:+")
    x$id <- "range1"
    y <- GRanges(c("chr1:51-60:+", "chr1:21-30:-"))
    xy <- intersectMC(x, y)
    expect_equal("chr1:51-60:+", as.character(xy))
    expect_equal(xy$id, "range1")
    xy <- intersectMC(x, y, ignore.strand = TRUE)
    expect_equal(as.character(xy), c("chr1:21-30", "chr1:51-60"))
    expect_equal(xy$id, rep("range1", 2))
})
steveped/extraChIPs documentation built on May 12, 2024, 2:55 p.m.