tests/testthat/test_scale_date_xx.R

context("scale_date_xx")


test_that("scale_date_xx works as expected", {
  if (!requireNamespace("ggplot2", quietly = TRUE)){
    skip("test requires ggplot2")
  }

  # Force all branches of the date_**_breaks and ensure no exception is raised
  # < 6
  tdf <- data.frame(
    yq = date_yq(2000, 1:4),
    ym = date_ym(2000, 4:7),
    yw = date_yw(2000, 21:24),
    vals = runif(4)
  )
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(x = yq, y = vals))))
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(x = ym, y = vals))))
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(x = yw, y = vals))))

  # > 6
  tdf <- data.frame(
    yq = date_yq(c(rep(1990, 4), rep(1991, 4)), c(1:4, 1:4)),
    ym = date_ym(1990, 1:8),
    yw = date_yw(1990, 1:8),
    vals = runif(8)
  )
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(y = yq, x = vals))))
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(y = ym, x = vals))))
  expect_silent(print(ggplot2::ggplot(tdf, ggplot2::aes(y = yw, x = vals))))

  # large
  expect_silent(date_yq_breaks()(date_yq(1950:2021, 1)))
  expect_silent(date_ym_breaks()(date_ym(1990:2021, 1)))

  expect_silent(date_yw_breaks()(date_yw(1910, c(1, 50))))
  expect_silent(date_yw_breaks()(date_yw(1910:2221, 1)))

  expect_silent(date_yq_breaks()(date_yq(NA, NA)))
  expect_silent(date_ym_breaks()(date_ym(NA, NA)))
  expect_silent(date_yw_breaks()(date_yw(NA, NA)))
})



test_that("date_yq_breaks doesnt fail for a variety of inputs", {

  x <- rep(date_yq(2018, 1), 5)
  expect_silent(date_yq_breaks()(x))

  qs <- 1:4
  ys <- 1800:2200
  nas <- c(0, 2, 5)
  pad <- 0:4

  for(i in 1:100){
    y <- sample(ys, 2, replace = TRUE)
    q <- sample(qs, 2, replace = TRUE)
    p <- sample(pad, 2, replace = TRUE)
    na <- sample(nas, 1)
    x <- seq(date_yq(y[[1]], q[[1]]), date_yq(y[[2]], q[[2]]))
    x[sample(1:length(x), na, replace = TRUE)] <- NA
    expect_silent(date_yq_breaks()(x))
  }

  ys <- 2000:2010


  for(i in 1:100){
    y <- sample(ys, 2, replace = TRUE)
    q <- sample(qs, 2, replace = TRUE)
    p <- sample(pad, 2, replace = TRUE)
    na <- sample(nas, 1)
    x <- seq(date_yq(y[[1]], q[[1]]), date_yq(y[[2]], q[[2]]))
    x[sample(1:length(x), na, replace = TRUE)] <- NA
    expect_silent(date_yq_breaks()(x))
  }

  ys <- 2000:2005

  for(i in 1:100){
    y <- sample(ys, 2, replace = TRUE)
    q <- sample(qs, 2, replace = TRUE)
    p <- sample(pad, 2, replace = TRUE)
    na <- sample(nas, 1)
    x <- seq(date_yq(y[[1]], q[[1]]), date_yq(y[[2]], q[[2]]))
    x[sample(1:length(x), na, replace = TRUE)] <- NA
    expect_silent(date_yq_breaks()(x))
  }
})



test_that("date_ym_breaks doesnt fail for a variety of inputs", {
  skip("not yet")
  x <- date_ym(2018, 1:12)
  date_ym_breaks()(x)
})




test_that("date_ym_trans is reversible", {
  x <- seq(date_ym(1950, 1), date_ym(2050, 1))
  trn <- date_ym_trans$transform(x)
  inv <- date_ym_trans$inverse(trn)
  expect_identical(x, inv)
})

Try the dint package in your browser

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

dint documentation built on Oct. 17, 2022, 9:06 a.m.