tests/testthat/test_plot_circle.R

context("Test plot_circle()")

# Load data
defuse833ke <- system.file(
  "extdata",
  "defuse_833ke_results.filtered.tsv",
  package = "chimeraviz")
fusions <- import_defuse(defuse833ke, "hg19", 3)
# Temporary file to store the plot
png_filename <- tempfile(
  pattern = "circlePlot",
  fileext = ".png",
  tmpdir = tempdir())

test_that("plot_circle produces a png file", {
  # Open device
  png(png_filename, width = 1000, height = 750)
  # Plot and expect certain message output
  plot_circle(fusions)
  # Close device
  dev.off()
  # See if we actually produced a file with size > 0
  expect_equal(file.info(png_filename)$size > 0, TRUE)
})

test_that("plot_circle() fails with invalid input", {
  # List without fusion objects?
  expect_error(plot_circle(list()))
  # List with fusion objects and something else?
  expect_error(plot_circle(c(fusions, "test")))
  # List with fusion objects where the genomes differ
  fusions[[1]]@genome_version <- "test"
  expect_error(plot_circle(fusions))
  # Inputs that are not lists?
  expect_error(plot_circle(42))
  expect_error(plot_circle("hey this should fail"))
})
stianlagstad/chimeraviz documentation built on Dec. 3, 2023, 8:11 p.m.