tests/testthat/test_toGRanges.R

library(regioneR)
context("toGRanges")

#Define some GRanges to use in the tests
starts <- c(1, 15, 24)
ends <- c(10, 20, 30)
chrs <- c("1", "1", "2")
A <- data.frame(chr=chrs, start=starts, end=ends,  x=c(1,2,3), y=c("a", "b", "c"))
gr1 <- toGRanges(A)



#from data.frame
test_that(" toGRanges works for a data.frame", {
  
  expect_is(gr1, "GRanges")
  expect_length(gr1, 3)
  expect_equal(names(mcols(gr1)), c("x", "y"))
  expect_is(gr1$x, "numeric")
  expect_is(gr1$y, "character")  
  expect_equal(GenomicRanges::start(gr1), starts)
  expect_equal(GenomicRanges::end(gr1), ends)
  expect_equal(as.character(seqnames(gr1)), chrs)
  
  gr1.2 <- toGRanges(data.frame(1, starts, ends))
  expect_equal(as.character(seqnames(gr1.2)), c("1", "1", "1"))

  expect_equal(toGRanges(1, starts, ends), gr1.2)
    
  expect_equal(toGRanges(toDataframe(gr1)), gr1)
  
  
  #check the genome
  expect_length(genome(gr1), 2)
  expect_length(genome(gr1.2), 1)

  gr1.3 <- toGRanges(A, genome = "hg19")
  expect_equal(seqlengths(gr1.3),   seqlengths(getGenome("hg19")))
  expect_equal(as.character(seqnames(gr1.3)), c("chr1", "chr1", "chr2"))
  
})


#from files
test_that(" toGRanges works for a file", {
  
  #Bed files 
  #using the rtracklayer example just check it does not error and the returned
  #object class is valid
  gr1 <- expect_silent(toGRanges(system.file("tests", "test.bed", package = "rtracklayer")))
  expect_is(gr1, "GRanges")
  
  #using our own test file, check the specific content
  gr1 <- expect_silent(toGRanges("test_data_files/regs.bed"))
  expect_is(gr1, "GRanges")
  expect_length(gr1, 3)
  expect_equal(width(gr1), c(9999, 10000, 1))
  expect_equal(ncol(mcols(gr1)), 0)
  expect_equal(as.character(seqnames(gr1)), c("1","1","2"))
  expect_equal(GenomicRanges::start(gr1), c(2, 20001, 2))
  expect_equal(GenomicRanges::end(gr1), c(10000, 30000, 2))
  
  #using an out-of-spec bed file with header
  expect_error(toGRanges("test_data_files/bed_with_header.bed"))
  
  
  #Generic files
  gr1 <- expect_silent(toGRanges("test_data_files/regs.txt"))
  expect_is(gr1, "GRanges")
  expect_length(gr1, 3)
  expect_equal(width(gr1), c(10000, 10001, 2))
  expect_equal(ncol(mcols(gr1)), 0)
  expect_equal(as.character(seqnames(gr1)), c("1","1","2"))
  expect_equal(GenomicRanges::start(gr1), c(1, 20000, 1))
  expect_equal(GenomicRanges::end(gr1), c(10000, 30000, 2))
  
  expect_equal(toGRanges("test_data_files/comments_and_header.txt"), gr1)
  
  expect_equal(toGRanges("test_data_files/two_valid_seps.txt"), gr1)
  
  
  #with an additional column
  gr1 <- expect_silent(toGRanges("test_data_files/4columns.txt"))
  expect_is(gr1, "GRanges")
  expect_length(gr1, 3)
  expect_equal(width(gr1), c(10000, 10001, 2))
  expect_equal(ncol(mcols(gr1)), 1)
  expect_equal(names(mcols(gr1)), "data")
  expect_equal(as.character(seqnames(gr1)), c("1","1","2"))
  expect_equal(GenomicRanges::start(gr1), c(1, 20000, 1))
  expect_equal(GenomicRanges::end(gr1), c(10000, 30000, 2))
  expect_equal(as.character(gr1$data), c("col", "nan", "col"))
  
  gr2 <- expect_silent(toGRanges("test_data_files/alt_sep1.txt"))
  names(mcols(gr2)) <- "data"
  expect_equal(gr2, gr1)
  
  gr2 <- expect_silent(toGRanges("test_data_files/alt_sep2.txt"))
  names(mcols(gr2)) <- "data"
  expect_equal(gr2, gr1)
  
  gr2 <- expect_silent(toGRanges("test_data_files/alt_sep2_with_other_seps.txt"))
  expect_is(gr2, "GRanges")
  expect_length(gr2, 3)
  expect_equal(width(gr2), c(10000, 10001, 2))
  expect_equal(ncol(mcols(gr2)), 1)
  expect_equal(names(mcols(gr2)), "V4")
  expect_equal(as.character(seqnames(gr2)), c("1","1","2"))
  expect_equal(GenomicRanges::start(gr2), c(1, 20000, 1))
  expect_equal(GenomicRanges::end(gr2), c(10000, 30000, 2))
  expect_equal(as.character(gr2$V4), c("col", "n\tan", "c;ol"))
  
  
  
  gr1 <- expect_silent(toGRanges("test_data_files/only_comments_and_header.txt"))
  expect_is(gr1, "GRanges") 
  expect_length(gr1, 0)  

  expect_equal(toGRanges("test_data_files/only_comments.txt"), gr1)
  
  expect_equal(toGRanges("test_data_files/empty_file.txt"), gr1)
  
})

#' A <- data.frame(chr=1, start=c(1, 15, 24), end=c(10, 20, 30),  x=c(1,2,3), y=c("a", "b", "c"))
#' gr1 <- toGRanges(A)
#' 
#' #No need to give the data.frame columns any specific name
#' A <- data.frame(1, c(1, 15, 24), c(10, 20, 30),  x=c(1,2,3), y=c("a", "b", "c"))
#' gr2 <- toGRanges(A)
#' 
#' #We can pass the data without building the data.frame
#' gr3 <- toGRanges("chr9", 34229289, 34982376, x="X")
#' 
#' #And each argument can be a vector (they will be recycled as needed)
#' gr4 <- toGRanges("chr9", c(34229289, 40000000), c(34982376, 50000000), x="X", y=c("a", "b"))
#' 
#' #toGRanges will automatically convert the second and third argument into numerics
#' gr5 <- toGRanges("chr9", "34229289", "34982376") 
#' 
#' #It can be a file from disk
#' bed.file <- system.file("extdata", "my.special.genes.bed", package="regioneR")
#' gr6 <- toGRanges(bed.file)
#' 
#' #Or a URL to a valid file
#' gr7 <- toGRanges("http://molb7621.github.io/workshop/_downloads/lamina.bed")
#' 
#' #It can also parse genomic location strings
#' gr8 <- toGRanges("chr9:34229289-34982376")
#' 
#' #more than one
#' gr9 <- toGRanges(c("chr9:34229289-34982376", "chr10:1000-2000"))
#' 
#' #even with mixed strange and mixed syntaxes
#' gr10 <- toGRanges(c("chr4:3873-92928", "chr4:3873,92928", "chr5:33,444-45,555"))
#' 
#' #if the genome is given it is used to annotate the resulting GRanges
#' gr11 <- toGRanges(c("chr9:34229289-34982376", "chr10:1000-2000"), genome="hg19")
#' 
#' 
#' #and the genome is added to the GRanges even if A is a GRanges
#' gr12 <- toGRanges(gr6, genome="hg19")
#' 
#' #And it will change the chromosome naming of the GRanges to match that of the
#' #genome if it is possible (using GenomeInfoDb::seqlevelsStyle)
#' gr2
#' gr13 <- toGRanges(gr2, genome="hg19")
#' 
#' #in addition, it can convert other objects into GRanges such as the 
#' #result of GenomicRanges::coverage
#' 
#' gr14 <- toGRanges(c("1:1-20", "1:5-25", "1:18-40"))
#' cover <- GenomicRanges::coverage(gr14)
#' gr15 <- toGRanges(cover)

Try the regioneR package in your browser

Any scripts or data that you put into this service are public.

regioneR documentation built on Nov. 8, 2020, 5 p.m.