65 lines
2.1 KiB
R
Raw Normal View History

2025-01-12 00:52:51 +08:00
test_IRanges_names <- function() {
range1 <- IRanges(start=c(1,2,3), end=c(5,2,8))
checkIdentical(names(range1), NULL)
nms <- c("a", NA, "b")
names(range1) <- nms
checkIdentical(names(range1), nms)
checkTrue(validObject(nms))
names(range1) <- NULL
checkTrue(validObject(nms))
checkIdentical(names(range1), NULL)
names(range1) <- "a"
checkTrue(validObject(range1))
checkIdentical(names(range1), c("a", NA, NA))
checkException(names(range1) <- c("a", "b", "c", "d"), silent = TRUE)
}
test_IntegerRanges_isDisjoint <- function() {
ir1 <- IRanges(c(2,5,1), c(3,7,3))
ir2 <- IRanges(c(2,9,5), c(3,9,6))
ir3 <- IRanges(1, 5)
checkIdentical(isDisjoint(ir1), FALSE)
checkIdentical(isDisjoint(ir2), TRUE)
checkIdentical(isDisjoint(ir3), TRUE)
## Handling of zero-width ranges
current <- sapply(11:17,
function(i)
isDisjoint(IRanges(c(12, i), width=c(4, 0))))
target <- rep(c(TRUE, FALSE, TRUE), c(2, 3, 2))
checkIdentical(target, current)
}
test_IRanges_concatenate <- function() {
range <- IRanges(start=c(1,2,3,1), end=c(5,2,8,3))
srange <- split(range, start(range) == 1)
checkIdentical(srange, IRangesList(`FALSE` = range[2:3], `TRUE` = range[c(1,4)]))
checkIdentical(do.call(c, unname(as.list(srange))),
IRanges(c(2,3,1,1), c(2,8,5,3)))
ir1 <- IRanges(1, 10)
ir2 <- IRanges(c(1, 15), width=5)
mcols(ir2) <- DataFrame(score=1:2)
checkIdentical(mcols(c(ir1, ir2)),
DataFrame(score = c(NA, 1L, 2L)))
## Concatenating multiple IRanges object with varying mcols
mcols(ir1) <- DataFrame(gc=0.78)
ir12 <- c(ir1, ir2, ignore.mcols=TRUE)
checkIdentical(mcols(ir12), NULL)
target_mcols <- DataFrame(gc=c(0.78, NA, NA), score=c(NA, 1:2))
mcols(ir12) <- target_mcols
checkIdentical(c(ir1, ir2), ir12)
}
test_IRanges_annotation <- function() {
range <- IRanges(c(1, 4), c(5, 7))
mcols(range) <- DataFrame(a = 1:2)
checkIdentical(mcols(range)[,1], 1:2)
checkIdentical(mcols(range[2:1])[,1], 2:1)
checkIdentical(mcols(c(range,range))[,1], rep(1:2,2))
}