tests/testthat/test-data.table.R

test_that("skim of a simple data.table produces no warnings", {
  skip_if_not_installed("data.table")
  withr::local_options(list(width = 91))
  DT_letters <- data.table::data.table(abc = letters)
  expect_warning(skim(DT_letters), NA)
})

test_that("skim of a simple data.table produces no warnings even with dtplyr", {
  skip_if_not_installed("data.table")
  skip_if_not_installed("dtplyr")
  withr::local_options(list(width = 91))
  DT_letters <- data.table::data.table(abc = letters)
  expect_warning(skim(DT_letters), NA)
})

test_that("skim of a simple data.table produces output as expected", {
  skip_if_not_installed("data.table")
  DT_letters <- data.table::data.table(abc = letters)

  skimmed_DT_letters <- skim(DT_letters)
  withr::local_options(list(cli.unicode = FALSE, width = 91))
  expect_print_matches_file(
    skimmed_DT_letters,
    "data.table/summary_DT_letters.txt"
  )
})


test_that("skim of data.table produces output as expected", {
  skip_if_not_installed("data.table")
  set.seed(1L)

  DT_factors <- data.table::data.table(
    abc = letters,
    grps = factor(sample(c("AA", "BB"), 26, TRUE)),
    values = rnorm(26)
  )

  withr::local_options(list(cli.unicode = FALSE, width = 91))

  expect_print_matches_file(
    skim(DT_factors),
    "data.table/summary_DT_factors_no_key.txt"
  )

  data.table::setkeyv(DT_factors, c("abc", "grps"))
  expect_print_matches_file(
    skim(DT_factors),
    "data.table/summary_DT_factors.txt"
  )

  DF_factors <- as.data.frame(DT_factors)
  expect_print_matches_file(
    skim(DF_factors),
    "data.table/summary_DF_factors.txt"
  )

  tibble_factors <- tibble::as_tibble(DT_factors)
  expect_print_matches_file(
    skim(tibble_factors),
    "data.table/summary_tibble_factors.txt"
  )
})

Try the skimr package in your browser

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

skimr documentation built on Dec. 28, 2022, 2:45 a.m.