tests/testthat/test-force_utc.R

test_that("force_utc doesn't preserve attributes we don't want", {
  x_ct <- as.POSIXct("2010-01-01 09:00", tz = "Pacific/Auckland")
  x_ct_forced <- force_utc(x_ct)
  expect_s3_class(x_ct_forced, "POSIXct")
  expect_null(attr(x_ct_forced, "names"))
  expect_equal(attr(x_ct_forced, "tzone"), "UTC")

  x_lt <- as.POSIXlt("2010-01-01 09:00", tz = "Pacific/Auckland")
  x_lt_forced <- force_utc(x_lt)
  expect_s3_class(x_lt_forced, "POSIXct")
  expect_null(attr(x_lt_forced, "names"))
  expect_equal(attr(x_lt_forced, "tzone"), "UTC")
})

test_that("force_utc works for dates as well as date times", {
  x_ct <- as.POSIXct("2010-01-01", tz = "Pacific/Auckland")
  x_ct_forced <- force_utc(x_ct)
  expect_s3_class(x_ct_forced, "POSIXct")
  expect_equal(attr(x_ct_forced, "tzone"), "UTC")
  expect_equal(format(x_ct, "%Y-%m-%d"), format(x_ct_forced, "%Y-%m-%d"))

  x_lt <- as.POSIXlt("2010-01-01", tz = "Pacific/Auckland")
  x_lt_forced <- force_utc(x_lt)
  expect_s3_class(x_lt_forced, "POSIXct")
  expect_equal(attr(x_lt_forced, "tzone"), "UTC")
  expect_equal(format(x_lt, "%Y-%m-%d"), format(x_lt_forced, "%Y-%m-%d"))
})

test_that("objects with UTC tz pass through unchanged", {
  x_ct <- as.POSIXct("2010-01-01 09:00", tz = "UTC")
  expect_identical(x_ct, force_utc(x_ct))

  x_lt <- as.POSIXlt("2010-01-01 09:00", tz = "UTC")
  expect_identical(x_lt, force_utc(x_lt))

  x_ct <- as.POSIXct("2010-01-01", tz = "UTC")
  expect_identical(x_ct, force_utc(x_ct))

  x_lt <- as.POSIXlt("2010-01-01", tz = "UTC")
  expect_identical(x_lt, force_utc(x_lt))
})

Try the haven package in your browser

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

haven documentation built on July 10, 2023, 2:04 a.m.