tests/testthat/test_create_motif.R

context("create_motif()")

test_that("motif creation for missing or from numeric input works", {

  expect_error(universalmotif_cpp())

  motif1 <- create_motif()
  motif2 <- create_motif(10)
  motif3 <- create_motif(type = "PCM")
  motif4 <- create_motif(type = "PWM")
  motif5 <- create_motif(type = "ICM")

  expect_s4_class(motif1, "universalmotif")

  expect_equal(ncol(motif1["motif"]), ncol(motif2["motif"]))
  expect_equal(motif1["type"], "PPM")
  expect_equal(as.numeric(colSums(motif1["motif"])), rep(1, 10))
  expect_equal(sum(motif1["motif"]), 10)
  expect_equal(motif1["alphabet"], "DNA")
  expect_equal(motif1["strand"], "+-")
  expect_equal(rownames(motif1["motif"]), c("A", "C", "G", "T"))
  expect_equal(motif1["pseudocount"], 0)
  expect_equal(sum(motif3["motif"]), 1000)
  expect_true(all(motif1["motif"] != motif2["motif"]))

  expect_true(any(motif4["motif"] < 0))
  expect_true(all(motif5["motif"] <= 2 & motif5["motif"] >= 0))

  expect_error(create_motif(0))
  expect_error(create_motif(1, 2))
  expect_error(create_motif(10.5))
  expect_error(create_motif(bkg = 0))
  expect_error(create_motif(bkg = c(0.2, 0.2, 0.2, 0.2, 0.2)))
  expect_error(create_motif(bkg = c(0.5, 0.5)))

})

test_that("motif creation from matrix input works", {

  mat <- matrix(c(0.1, 0.7, 0.1, 0.7, 0.4,
                  0.1, 0.1, 0.1, 0.1, 0.1,
                  0.1, 0.1, 0.1, 0.1, 0.1,
                  0.7, 0.1, 0.7, 0.1, 0.4),
                nrow = 4, byrow = TRUE)
  mat2 <- mat * 10

  motif1 <- create_motif(mat, alphabet = "QWER")
  motif2 <- create_motif(mat, alphabet = "DNA")
  motif3 <- create_motif(mat2, alphabet = "RNA")
  motif4 <- convert_type(motif3, type = "PWM")

  mat3 <- motif4["motif"]

  motif5 <- create_motif(mat3)
  motif5["nsites"] <- 10
  motif6 <- create_motif(mat2, alphabet = "QWER", type = "PCM")

  expect_equal(motif1["alphabet"], "EQRW")
  expect_equal(motif2["consensus"], "TATAW")
  expect_equal(motif3["consensus"], "UAUAW")
  expect_equal(motif3["nsites"], 10)
  expect_true(all(motif6["motif"] >= 1))
  expect_true(any(motif4["motif"] < 0))
  # expect_identical(motif5, motif3)  # this tests fails on travis?

})

test_that("motif creation from XStringSet works", {

  s1 <- create_sequences("DNA", seqlen = 10, seqnum = 100)
  s2 <- create_sequences("RNA", seqlen = 10, seqnum = 100)
  s3 <- create_sequences("AA", seqlen = 10, seqnum = 100)
  s4 <- create_sequences("QWERTY", seqlen = 10, seqnum = 100)

  motif1 <- create_motif(s1, add.multifreq = 2:3)
  motif2 <- create_motif(s2, add.multifreq = 2:3)
  motif3 <- create_motif(s3, add.multifreq = 2:3)
  motif4 <- create_motif(s4, add.multifreq = 2:3)

  expect_equal(motif1["nsites"], 100)
  expect_equal(motif2["nsites"], 100)
  expect_equal(motif3["nsites"], 100)
  expect_equal(motif4["nsites"], 100)

  expect_equal(motif1["alphabet"], "DNA")
  expect_equal(motif2["alphabet"], "RNA")
  expect_equal(motif3["alphabet"], "AA")
  expect_equal(motif4["alphabet"], "EQRTWY")

  expect_equal(names(motif1["multifreq"]), c("2", "3"))
  expect_equal(names(motif2["multifreq"]), c("2", "3"))
  expect_equal(names(motif3["multifreq"]), c("2", "3"))
  expect_equal(names(motif4["multifreq"]), c("2", "3"))

})

test_that("motif creation from character input works", {

  s <- c("ACGACGAT", "GATCGATG", "GATCGACC", "TAGCTACG")

  m <- create_motif(s, "DNA")

  expect_equal(m["nsites"], 4)
  expect_equal(m["consensus"],  "NAKCNANN")
  expect_equal(round(m@icscore, 3), 6.566)

  m2 <- create_motif("NNNN")

  expect_equal(m2["icscore"], 0)

})
bjmt/universalmotif documentation built on March 18, 2024, 8:32 a.m.