tests/testthat/test-graphics.R

suppressWarnings(context("graphics"))

test_that("display works", {
  skip_if_not_installed("vdiffr")
  skip_if_not_installed("EBImage")
  skip_if(getRversion() < "4.0")
  img <- read_tif(system.file("img", "Rlogo.tif", package = "ijtiff"),
    msg = FALSE
  )
  grDevices::pdf(tempfile(pattern = ".pdf"))
  expect_equal(
    display(img, basic = TRUE),
    display(structure(img, dim = dim(img)[-length(dim(img))]), basic = TRUE)
  )
  vdiffr::expect_doppelganger("raster R logo", display(img, method = "r"))
  img <- read_tif(system.file("img", "Rlogo.tif", package = "ijtiff"),
    msg = FALSE
  ) %>%
    as_EBImage() %>%
    EBImage::resize(h = dim(.)[1] / 4, w = dim(.)[2] / 4) %>%
    as_ijtiff_img()
  vdiffr::expect_doppelganger(
    "reduced resolution basic R logo",
    display(img, basic = TRUE)
  )
  img <- read_tif(system.file("img", "Rlogo.tif", package = "ijtiff"),
    msg = FALSE
  )
  expect_message(
    display(img[, , , ], method = "r"),
    "first frame.+displayed.+use.+all.+TRUE"
  )
  vdiffr::expect_doppelganger(
    "raster grey R logo",
    suppressMessages(display(img[, , , ], method = "r"))
  )
  vdiffr::expect_doppelganger(
    "raster grey r logo (blue channel)",
    display(img[, , 2, ], method = "r")
  )
  vdiffr::expect_doppelganger(
    "raster R logo (green channel)",
    display(img[, , 3, 1])
  )
  img <- read_tif(test_path("testthat-figs", "Rlogo-banana-red.tif"),
    msg = FALSE
  )
  vdiffr::expect_doppelganger(
    "R logo banana red",
    suppressMessages(display(img, method = "r"))
  )
  skip_if_not_installed("mockery")
  mockery::stub(display, "rlang::is_installed", FALSE)
  expect_message(
    display(img),
    "Using basic display.+For better.+install.+EBImage"
  )
  grDevices::dev.off()
})

Try the ijtiff package in your browser

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

ijtiff documentation built on June 22, 2024, 11:54 a.m.