tests/testthat/test-sparse_median.R

test_that("sparse_median() works", {
  x <- sparse_double(10, 5, 1000)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(10, -10), c(5, 100), 1000)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(10, -10), c(5, 100), 1000, default = 20)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000, default = 100)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000)

  expect_equal(median(x, na.rm = TRUE), sparse_median(x, na_rm = TRUE))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000, default = 100)

  expect_equal(median(x, na.rm = TRUE), sparse_median(x, na_rm = TRUE))

  x <- sparse_double(numeric(), integer(), 1000)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(numeric(), integer(), 1000, default = 100)

  expect_equal(median(x), sparse_median(x))
})

test_that("sparse_median() edge cases", {
  x <- sparse_double(c(10, 10), c(1, 2), 4)

  expect_equal(median(x), sparse_median(x))

  x <- sparse_double(c(10, NA), c(1, 2), 4)

  expect_equal(median(x), sparse_median(x))
  expect_equal(median(x, na.rm = TRUE), sparse_median(x, na_rm = TRUE))

  x <- sparse_double(c(10, 10, NA), c(1, 2, 3), 5)

  expect_equal(median(x), sparse_median(x))
  expect_equal(median(x, na.rm = TRUE), sparse_median(x, na_rm = TRUE))
})

Try the sparsevctrs package in your browser

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

sparsevctrs documentation built on June 8, 2025, 1:48 p.m.