inst/tinytest/test-dsvg.R

library(tinytest)
library(ggiraph)
library(xml2)
source("setup.R")

# svg creation ------------------------------------------------------------
{
  doc <- dsvg_doc(width = 6, height = 5, {
    plot.new()
  })
  expect_inherits(doc, "xml_document")
  root_node <- xml_root(doc)
  expect_inherits(root_node, "xml_node")
  expect_equal(xml_name(root_node), "svg")

  expect_equal(
    xml_attr(root_node, "viewBox"),
    paste(0, 0, 6 * 72, 5 * 72),
    info = "svg viewBox is set"
  )

  expect_equal(length(xml_children(root_node)), 2)
  defs_node <- xml_find_first(doc, "/svg/defs")
  expect_inherits(defs_node, "xml_node")
  g_node <- xml_find_first(doc, "/svg/g")
  expect_inherits(g_node, "xml_node")
}

# svg dimensions ----------------------------------------------------------
{
  doc <- dsvg_doc(width = 6, height = 5, setdims = TRUE, {
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_equal(as.numeric(xml_attr(root_node, "width")), 6 * 72)
  expect_equal(as.numeric(xml_attr(root_node, "height")), 5 * 72)

  doc <- dsvg_doc(width = 6, height = 5, setdims = FALSE, {
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_false(xml_has_attr(root_node, "width"))
  expect_false(xml_has_attr(root_node, "height"))
}

# svg standalone ----------------------------------------------------------
{
  doc <- dsvg_doc(standalone = TRUE, srip_ns = FALSE, {
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_equal(xml_attr(root_node, "xmlns"), "http://www.w3.org/2000/svg")
  expect_equal(xml_attr(root_node, "xmlns:xlink"), "http://www.w3.org/1999/xlink")

  doc <- dsvg_doc(standalone = FALSE, {
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_false(xml_has_attr(root_node, "xmlns"))
  expect_false(xml_has_attr(root_node, "xmlns:xlink"))
}

# svg background ----------------------------------------------------------
{
  doc <- dsvg_doc(bg = "#123456", {
    plot.new()
  })
  bg_node <- xml_find_first(doc, "/svg/g//rect")
  expect_inherits(bg_node, "xml_node")
  expect_equal(xml_attr(bg_node, "fill"), "#123456")
  expect_equal(xml_attr(bg_node, "fill-opacity"), "1")

  doc <- dsvg_doc(bg = "#12345699", {
    plot.new()
  })
  bg_node <- xml_find_first(doc, "/svg/g//rect")
  expect_equal(xml_attr(bg_node, "fill-opacity"), "0.6")

  doc <- dsvg_doc(bg = "transparent", {
    plot.new()
  })
  bg_node <- xml_find_first(doc, "/svg/g//rect")
  expect_inherits(bg_node, "xml_missing")
}

# svg title/desc ----------------------------------------------------------
{
  doc <- dsvg_doc(title = "title", desc = "desc", {
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_equal(xml_attr(root_node, "aria-labelledby"), "svgid_title")
  expect_equal(xml_attr(root_node, "aria-describedby"), "svgid_desc")
  title_node <- xml_find_first(doc, "/svg/title")
  expect_equal(xml_attr(title_node, "id"), "svgid_title")
  expect_equal(xml_text(title_node), "title")
  desc_node <- xml_find_first(doc, "/svg/desc")
  expect_equal(xml_attr(desc_node, "id"), "svgid_desc")
  expect_equal(xml_text(desc_node), "desc")

  doc <- dsvg_doc({
    plot.new()
  })
  root_node <- xml_root(doc)
  expect_false(xml_has_attr(root_node, "aria-labelledby"))
  expect_false(xml_has_attr(root_node, "aria-describedby"))
  title_node <- xml_find_first(doc, "/svg/title")
  expect_inherits(title_node, "xml_missing")
  desc_node <- xml_find_first(doc, "/svg/desc")
  expect_inherits(desc_node, "xml_missing")
}

# dsvg accepts only one page ----------------------------------------------
{
  expect_error(
    dsvg_doc({
      plot.new()
      plot.new()
    }),
    info = "dsvg accepts only one page"
  )
}

# dsvg arguments ----------------------------------------------
{
  expect_error(dsvg(file = NULL), info = "check file argument")
  expect_error(dsvg(width = -5), info = "check width argument")
  expect_error(dsvg(height = -5), info = "check height argument")
  expect_error(dsvg(bg = NA), info = "check bg argument")
  expect_error(dsvg(pointsize = 0), info = "check pointsize argument")
  expect_error(dsvg(standalone = NULL), info = "check standalone argument")
  expect_error(dsvg(setdims = NULL), info = "check setdims argument")
  expect_error(dsvg(canvas_id = NULL), info = "check canvas_id argument")
  expect_error(dsvg(fonts = NULL), info = "check fonts argument")
}

Try the ggiraph package in your browser

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

ggiraph documentation built on March 31, 2023, 9:53 p.m.