tests/testthat/test-zz-fuzz.R

local_edition(2)


# how to debug
# look for a 6 figure number in test output.
# Run:
#   library(huxtable)
# Source `add_props()`, the `variations` data frame and the `hx_raw` huxtable.
# run:
#   hx_set <- add_props(hx_raw, variations[six_figure_no,])
# compare outputs to something like
# cat(readRDS("tests/testthat/output-rds/various-outputs-six_figure_no-..."))
# or run quick_xxx functions on it

expect_outputs_unchanged <- function (hx, idx) {
  info <- paste0("Index i = ", idx)
  file <- file.path(test_path(), "output-rds", paste0("various-outputs-", idx))
  # setting the width avoids problems that command line and RStudio tests have different
  # options(width)
  expect_known_value(to_screen(hx, min_width = 20, max_width = 80),
        file = paste0(file, "-screen.rds"), info = info)
  expect_known_value(to_md(hx, min_width = 20, max_width = 80), file = paste0(file, "-md.rds"),
        info = info)
  expect_known_value(to_html(hx),   file = paste0(file, "-html.rds"),   info = info)
  expect_known_value(to_latex(hx),  file = paste0(file, "-latex.rds"),  info = info)
  expect_known_value(to_rtf(hx),  file = paste0(file, "-rtf.rds"),  info = info)
}


variations <- expand.grid(
  align             = c("left", "right", "centre", "."),
  background_color  = c("red", grey(.6), NA),
  bold              = c(TRUE, FALSE),
  escape_contents   = c(TRUE, FALSE),
  font_size         = c(8, 10),
  italic            = c(TRUE, FALSE),
  left_border       = c(0, 1, 2),
  left_border_color = c("red", grey(.6)),
  left_border_style = c("double", "dotted", "dashed"),
  left_padding      = c(0, 4),
  number_format     = c("%3.1g", NA),
  rotation          = c(0, 90),
  text_color        = c("red", grey(.6)),
  valign            = c("top", "middle", "bottom"),
  wrap              = c(TRUE, FALSE),
  stringsAsFactors  = FALSE,
  KEEP.OUT.ATTRS    = FALSE
)

variations$left_border[variations$left_border_style == "double"] <- 3

hx_raw <- hux(
  int  = 1:3,
  real = 1:3 + 0.005,
  char = letters[1:3],
  date = as.Date(1:3, origin = "1970-01-01"),
  fact = factor(letters[4:6]),
  add_colnames = TRUE
)


add_props <- function(hx, row) {
  props <- as.list(row)
  props$ht <- hx
  props_no_border <- props[! grepl("border", names(props))]
  hx_set <- do.call("set_cell_properties", props_no_border)
  if ("left_border" %in% names(props)) {
    hx_set <- set_left_border(hx_set, props$left_border)
  }
  if ("left_border_style" %in% names(props)) {
    hx_set <- set_left_border_style(hx_set, props$left_border_style)
  }
  if ("left_border_color" %in% names(props)) {
    hx_set <- set_left_border_color(hx_set, props$left_border_color)
  }

  return(hx_set)
}


test_that("various outputs unchanged", {
  skip_on_R_CMD_check()

  RNGversion("3.3.0")
  set.seed(271075L) # expect_unchanged is useless if we always pick new variations
  for (i in sample(nrow(variations), 300)) {
    hx_set <- add_props(hx_raw, variations[i, ])
    expect_outputs_unchanged(hx_set, i)
  }
})


test_that("Some random outputs compile", {
  skip_on_R_CMD_check()

  n_tests <- get0("N_OUTPUT_TESTS", envir = globalenv(), ifnotfound = 10)

  outfiles <- character(n_tests * 4)
  on.exit({
    try(file.remove(outfiles), silent = TRUE)
  })

  sample_rows <- sample(nrow(variations), n_tests * 4)
  for (i in seq_len(n_tests)) {
    sr <- sample_rows[i]
    hx_set <- add_props(hx_raw, variations[sr, ])
    pdfo <- sprintf("pdf-check-%d.pdf", sr)
    outfiles[i] <- pdfo
    expect_error(quick_pdf(hx_set, file = pdfo, open = FALSE), regexp = NA, info = list(index = sr))
    expect_true(file.exists(pdfo), info = list(index = sr))
  }

  skip_if_not_installed("openxlsx")

  for (i in seq(n_tests + 1, 2 * n_tests)) {
    sr <- sample_rows[i]
    hx_set <- add_props(hx_raw, variations[sr, ])
    xlsxo <- sprintf("xlsx-check-%d.xlsx", sr)
    outfiles[i] <- xlsxo
    expect_error(quick_xlsx(hx_set, file = xlsxo, open = FALSE), regexp = NA, info = list(index = sr))
    expect_true(file.exists(xlsxo), info = list(index = sr))
  }

  skip_if_not_installed("flextable")

  for (i in seq(2 * n_tests + 1, 3 * n_tests)) {
    sr <- sample_rows[i]
    hx_set <- add_props(hx_raw, variations[sr, ])
    docxo <- sprintf("docx-check-%d.docx", sr)
    outfiles[i] <- docxo
    expect_error(quick_docx(hx_set, file = docxo, open = FALSE), regexp = NA,
          info = list(index = sr))
    expect_true(file.exists(docxo), info = list(index = sr))
  }

  for (i in seq(3 * n_tests + 1, 4 * n_tests)) {
    sr <- sample_rows[i]
    hx_set <- add_props(hx_raw, variations[sr, ])
    pptxo <- sprintf("pptx-check-%d.pptx", sr)
    outfiles[i] <- pptxo
    expect_error(quick_pptx(hx_set, file = pptxo, open = FALSE), regexp = NA,
      info = list(index = sr))
    expect_true(file.exists(pptxo), info = list(index = sr))
  }
})


test_that("Some random HTML outputs are validated by W3C", {
  skip_on_R_CMD_check()
  skip_if_not_installed("httr")
  library(httr)

  # here we do randomize
  for (i in sample(nrow(variations), 10)) {
    hx_set <- add_props(hx_raw, variations[i, ])
    webpage <- paste0("<!DOCTYPE html><html lang=\"en\">",
      "<head><meta charset=\"utf-8\"><title>huxtable table validation</title></head>",
      "<body>\n", to_html(hx_set), "\n</body></html>")
    response <- httr::POST("http://validator.w3.org/nu/?out=json", body = webpage,
          httr::content_type("text/html"))
    response <- httr::content(response, "parsed")
    errors   <- Filter(function (x) x$type == "error", response$messages)
    warnings <- Filter(function (x) x$type == "warnings", response$messages)
    valid <- length(errors) == 0
    expect_true(valid, info = list(index = i, errors = errors, warnings = warnings))
  }
})
hughjonesd/huxtable documentation built on Feb. 17, 2024, 12:20 a.m.