tests/testthat/test-pivot.R

# multi_id_pivot_wider ----

test_that("multi_id_pivot_wider works as expected.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_val = c(65, 165, "M", 66, "F", 166, 155, NA)
  )

  expected_data <- data.frame(
    the_obs = c("A", "B", "C", "D"),
    the_obs2 = c("Ax", "Bx", "Cx", "Dx"),
    gender = c("M", "F", NA, NA),
    height = c("165", "166", "155", NA),
    precondition = as.character(c(NA, NA, NA, NA)),
    weight = c("65", "66", NA, NA)
  )

  res <- expect_silent(multi_id_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", "the_val"))
  expect_identical(res, expected_data)
})

test_that("multi_id_pivot_wider works as expected with factor as value.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_val = factor(c(65, 165, "M", 66, "F", 166, 155, NA))
  )

  expected_data <- data.frame(
    the_obs = c("A", "B", "C", "D"),
    the_obs2 = c("Ax", "Bx", "Cx", "Dx"),
    gender = factor(c("M", "F", NA, NA), c("155", "165", "166", "65", "66", "F", "M")),
    height = factor(c("165", "166", "155", NA), c("155", "165", "166", "65", "66", "F", "M")),
    precondition = factor(c(NA, NA, NA, NA), c("155", "165", "166", "65", "66", "F", "M")),
    weight = factor(c("65", "66", NA, NA), c("155", "165", "166", "65", "66", "F", "M"))
  )

  res <- expect_silent(multi_id_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", "the_val"))
  expect_identical(res, expected_data)
})

test_that("multi_id_pivot_wider works as expected with factor as value and drop_lvl = TRUE", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_val = factor(c(65, 165, "M", 66, "F", 166, 155, NA))
  )

  expected_data <- data.frame(
    the_obs = c("A", "B", "C", "D"),
    the_obs2 = c("Ax", "Bx", "Cx", "Dx"),
    gender = factor(c("M", "F", NA, NA), c("F", "M")),
    height = factor(c("165", "166", "155", NA), c("155", "165", "166")),
    precondition = factor(c(NA, NA, NA, NA)),
    weight = factor(c("65", "66", NA, NA), c("65", "66"))
  )

  res <- expect_silent(
    multi_id_pivot_wider(
      test_data,
      c("the_obs", "the_obs2"), "the_param", "the_val",
      drop_lvl = TRUE
    )
  )
  expect_identical(res, expected_data)
})

test_that("multi_id_pivot_wider works as expected with drop_na argument.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_val = c(65, 165, "M", 66, "F", 166, 155, NA)
  )

  expected_data <- data.frame(
    the_obs = c("A", "B", "C", "D"),
    the_obs2 = c("Ax", "Bx", "Cx", "Dx"),
    gender = c("M", "F", NA, NA),
    height = c("165", "166", "155", NA),
    weight = c("65", "66", NA, NA)
  )

  res <- expect_silent(
    multi_id_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", "the_val", drop_na = TRUE)
  )
  expect_identical(expected_data, res)
})

test_that("multi_id_pivot_wider works as expected with drop_na argument.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_val = c(65, 165, "M", 66, "F", 166, 155, NA)
  )

  expected_data <- data.frame(
    the_obs = c("A", "B", "C", "D"),
    the_obs2 = c("Ax", "Bx", "Cx", "Dx"),
    gender = c("M", "F", NA, NA),
    height = c("165", "166", "155", NA),
    weight = c("65", "66", NA, NA)
  )

  res <- expect_silent(
    multi_id_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", "the_val", drop_na = TRUE)
  )
  expect_identical(expected_data, res)
})

test_that("multi_id_pivot_wider works as expected when the unique identification depends on several columns", {
  test_data <- data.frame(
    the_obs = c("A", "A", "B"),
    the_obs2 = c("Ax2", "Ax2", "Ax"),
    the_param = c("weight", "weight", "weight"),
    the_val = c(65, 65, 65)
  )

  expect_error(multi_id_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", "the_val"))

  test_data2 <- data.frame(
    the_obs = c("A", "A", "B"),
    the_obs2 = c("Ax", "Ax2", "Ax"),
    the_param = c("weight", "weight", "weight"),
    the_val = c(65, 65, 65)
  )

  expected_data <- data.frame(
    the_obs = c("A", "A", "B"),
    the_obs2 = c("Ax", "Ax2", "Ax"),
    weight = c(65, 65, 65)
  )

  res <- expect_silent(multi_id_pivot_wider(test_data2, c("the_obs", "the_obs2"), "the_param", "the_val"))
  expect_identical(res, expected_data)
})

# poly_pivot_wider ----

test_that("poly_pivot_wider works as expected.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_label = c(
      "Weight (Kg)", "Height (cm)", "Gender",
      "Weight (Kg)", "Gender", "Height (cm)", "Height (cm)", "Pre-condition"
    ),
    the_val = c(65, 165, NA, 66, NA, 166, 155, NA),
    the_val2 = c(65, 165, "M", 66, "F", 166, 155, TRUE)
  )

  res <- poly_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", c("the_val", "the_val2"), "the_label")

  checkmate::expect_list(res, len = 2)

  the_obs <- c("A", "B", "C", "D")
  the_obs2 <- c("Ax", "Bx", "Cx", "Dx")
  height <- c(165, 166, 155, NA)
  weight <- c(65, 66, NA, NA)

  attr(the_obs, "label") <- "the_obs"
  attr(the_obs2, "label") <- "the_obs2"
  attr(height, "label") <- "Height (cm)"
  attr(weight, "label") <- "Weight (Kg)"

  expected_data1 <- data.frame(
    the_obs = the_obs,
    the_obs2 = the_obs2,
    height = height,
    weight = weight
  )

  expect_identical(res[[1]], expected_data1)
})

test_that("poly_pivot_wider works as expected with default label.", {
  test_data <- data.frame(
    the_obs = c("A", "A", "A", "B", "B", "B", "C", "D"),
    the_obs2 = c("Ax", "Ax", "Ax", "Bx", "Bx", "Bx", "Cx", "Dx"),
    the_param = c("weight", "height", "gender", "weight", "gender", "height", "height", "precondition"),
    the_label = c(
      "Weight (Kg)", "Height (cm)", "Gender", "Weight (Kg)",
      "Gender", "Height (cm)", "Height (cm)", "Pre-condition"
    ),
    the_val = c(65, 165, NA, 66, NA, 166, 155, NA),
    the_val2 = c(65, 165, "M", 66, "F", 166, 155, TRUE)
  )

  res <- poly_pivot_wider(test_data, c("the_obs", "the_obs2"), "the_param", c("the_val", "the_val2"))

  checkmate::expect_list(res, len = 2)

  the_obs <- c("A", "B", "C", "D")
  the_obs2 <- c("Ax", "Bx", "Cx", "Dx")
  height <- c(165, 166, 155, NA)
  weight <- c(65, 66, NA, NA)

  attr(the_obs, "label") <- "the_obs"
  attr(the_obs2, "label") <- "the_obs2"
  attr(height, "label") <- "height"
  attr(weight, "label") <- "weight"

  expected_data1 <- data.frame(
    the_obs = the_obs,
    the_obs2 = the_obs2,
    height = height,
    weight = weight
  )

  expect_identical(res[[1]], expected_data1)
})

Try the dunlin package in your browser

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

dunlin documentation built on Oct. 31, 2024, 5:07 p.m.