tests/testthat/test-trans-compose.R

test_that("composes transforms correctly", {
  t <- transform_compose("log10", "reverse")
  expect_equal(t$transform(100), -2)
  expect_equal(t$inverse(-2), 100)
})

test_that("composes derivatives correctly", {
  t <- transform_compose("sqrt", "reciprocal", "reverse")
  expect_equal(t$d_transform(0.25), 4)
  expect_equal(t$d_inverse(-2), 0.25)
})

test_that("produces NULL derivatives if not all transforms have derivatives", {
  t <- transform_compose("sqrt", new_transform("no_deriv", identity, identity))
  expect_null(t$d_transform)
  expect_null(t$d_inverse)
})

test_that("uses breaks from first transformer", {
  t <- transform_compose("log10", "reverse")
  expect_equal(t$breaks(c(1, 1000)), log_breaks()(c(1, 1000)))
})

test_that("produces informative errors", {
  expect_snapshot(error = TRUE, {
    transform_compose()
    transform_compose("sqrt", "reverse", "log10")
  })
})

test_that("produces correct domains", {
  expect_equal(transform_compose("sqrt", "reverse")$domain, c(0, Inf))
  expect_equal(transform_compose("sqrt", "log")$domain, c(0, Inf))
  expect_equal(transform_compose("log", "log")$domain, c(1, Inf))
  expect_equal(transform_compose("reverse", "log")$domain, c(-Inf, 0))
  expect_equal(transform_compose("reverse", "logit", "log")$domain, c(-1, -0.5))
  expect_error(transform_compose("sqrt", "reverse", "log")$domain, "invalid domain")
})
hadley/scales documentation built on Jan. 10, 2024, 2:06 p.m.