tests/testthat/test-modify_tx.R

test_that("modify_tx works with toy example data", {

  # example data
  transcripts <- GenomicRanges::GRangesList(list(
    tx1 = GenomicRanges::GRanges(
      c("1", "1", "1", "1"),
      IRanges::IRanges(
        c(5, 12, 18, 25),
        c(8, 14, 21, 26),
      ),
      strand = c("+", "+", "+", "+")
    ),
    tx2 = GenomicRanges::GRanges(
      c("1", "1"),
      IRanges::IRanges(
        c(5, 18),
        c(8, 21),
      ), strand = c("-", "-")
    ),
    tx3 = GenomicRanges::GRanges(
      c("1", "1"),
      IRanges::IRanges(
        c(5, 12),
        c(8, 14),
      ), strand = c("+", "+")
    )
  ))

  # junction examples
  junc_df = tibble::tribble(
    ~"chr", ~"pos1", ~"pos2", ~"strand", ~"comment",

    "1",  2, 12, "+", "intron-exon",
    "1",  7, 12, "+", "alt 5prime in exon, pos",
    "1",  8, 15, "-", "alt 5prime in intron, neg",
    "1",  8, 18, "+", "exon skipping, pos",
    "1",  8, 9, "+", "intron retention at 5prime, pos",
    "1",  11, 12, "+", "intron retention at 3prime, pos",
    "1",  8, 10, "+", "alt 3prim in intron, pos",
    "1",  8, 13, "-", "alt 5prim in exon, neg",
    "1",  6, 7, "+", "adjacent within exon, no effect!"
  ) %>%
    dplyr::mutate(
      junc_id = generate_junction_id(chr, pos1, pos2, strand)
    )

  # Test with toy data ---------------------------------------------------------
  tx <- transcripts[c(1, 3)]
  jx <- GenomicRanges::GRanges(junc_df$chr,
                               IRanges::IRanges(junc_df$pos1, junc_df$pos2),
                                strand = junc_df$strand)[c(2, 2)]

  tx_alt <- modify_tx(tx, jx)

  expect_equal(length(tx_alt), length(tx))
  expect_equal(S4Vectors::end(tx_alt[[1]])[1], 7)

  # Test with full example data ---------------------------------------------------------
  junc_tx_df <- junc_df %>%
    add_tx(transcripts) %>%
    filter(!is.na(tx_id))

  jx <- junc_to_gr(junc_tx_df$junc_id)
  tx <- junc_tx_df$tx_lst

  tx_alt <- modify_tx(tx, jx)

  expect_equal(length(tx_alt), length(tx))
  # expect_equal(S4Vectors::end(tx_alt[[1]])[1], 7)

})

test_that("modify_tx works with negativ strand", {
  jx <- GenomicRanges::GRanges("1:8-15:-")
  tx <- GenomicRanges::GRangesList(
    GenomicRanges::GRanges(c("1:5-8:-", "1:18-21:-"))
  )
  tx_alt <- modify_tx(tx, jx)
  expect_equal(length(tx_alt), length(tx))
})

test_that("modify_tx work for exon exclusion junctions on toy data", {

  tx <- GenomicRanges::GRangesList(list(
    GenomicRanges::GRanges(c("1:2-3:+",
                             "1:5-6:+",
                             "1:10-15:+"))
    ))

  jx <- GenomicRanges::GRanges(c("1:3-10:+"))

  tx_alt <- modify_tx(tx, jx)

  expect_equal(length(tx_alt), length(tx))
  expect_equal(tx_alt[[1]], tx[[1]][c(1, 3)])

})


test_that("modify_tx work for exitorn junction on toy data", {

  tx <- GenomicRanges::GRangesList(list(
    GenomicRanges::GRanges(c("1:2-3:+",
                             "1:10-30:+",
                             "1:40-50:+"))
  ) %>% rep(3))

  jx <- GenomicRanges::GRanges(c(
    "1:3-10:+",  # canonical
    "1:15-20:+", # exitron in second exon
    "1:30-40:+"  # canonical
  ))

  tx_alt <- modify_tx(tx, jx)

  expect_equal(length(tx_alt[[2]]), length(tx[[2]]) + 1)
  expect_equal(tx_alt[[1]], tx[[1]])
  expect_equal(tx_alt[[3]], tx[[3]])
  expect_equal(length(tx_alt), length(tx))

})

test_that("modify_tx works with provided toy example data", {

  jx <- junc_to_gr(toy_junc_id)
  tx <- toy_transcripts[toy_junc_id_enst]

  alt_tx <- modify_tx(tx, jx)

  expect_equal(length(alt_tx), length(tx))
})


test_that("modify_tx works on custom develop data", {

  tx <- GenomicRanges::GRangesList(list(
    tx1 = GenomicRanges::GRanges(c(
      "c:1-2",
      "c:5-10",
      "c:15-20"
    )),
    tx2 = GenomicRanges::GRanges(c(
      "c:1-2",
      "c:5-10"
    ))
  ))

  jx <- GenomicRanges::GRanges(c(
    "c:12-15",
    "c:2-3")
    )

  ##############################################################################
  #      0        1         2
  #      123456789012345678901234567890
  #tx1   ==  ======    ======
  #tx2   ==  ======
  #jx1              |--|
  #jx2    ||
  #n1    ==  ========  ======
  #n1    ==========
  ##############################################################################

  tx_alt <- modify_tx(tx, jx)

  # build expected transcripts
  tx_exp <- GenomicRanges::GRangesList(list(
    tx1 = GenomicRanges::GRanges(c(
      "c:1-2",
      "c:5-12",
      "c:15-20"
    )),
    tx2 = GenomicRanges::GRanges(c(
      "c:1-10"
    ))
  ))

  expect_equal(tx_alt, tx_exp)

})
TRON-Bioinformatics/splice2neo documentation built on Nov. 9, 2024, 5:28 p.m.