tests/testthat/test-map.R

context("map")

test_that("list.map", {

  # simple list
  x <- list(p1 = list(type = "A", score = list(c1 = 10, c2 = 8)), p2 = list(type = "B",
    score = list(c1 = 9, c2 = 9)), p3 = list(type = "B", score = list(c1 = 9,
    c2 = 7)))

  expect_identical(list.map(x, score$c1), list(p1 = 10, p2 = 9, p3 = 9))

  # list of vectors
  x <- list(a = c(x = 1, y = 2), b = c(x = 3, y = 4))
  expect_identical(list.map(x, sum(.)), list(a = 3, b = 7))

  lapply(1:3, function(i) list.map(x, sum(.) + i))
})

test_that("list.mapv", {
  # simple list
  x <- list(p1 = list(type = "A", score = list(c1 = 10, c2 = 8)), p2 = list(type = "B",
    score = list(c1 = 9, c2 = 9)), p3 = list(type = "B", score = list(c1 = 9,
    c2 = 7)))

  expect_equal(list.mapv(x, score$c1), c(p1 = 10, p2 = 9, p3 = 9))
  expect_equal(list.mapv(x, x ~ sum(unlist(x$score))), c(p1 = 18, p2 = 18, p3 = 16))
  expect_identical(list.mapv(x, score$c1, "integer"), c(p1 = 10L, p2 = 9L, p3 = 9L))
  expect_identical(list.mapv(x, score$c1, "integer", use.names = FALSE), c(10L,
    9L, 9L))

  # list of vectors
  x <- list(a = c(x = 1, y = 2), b = c(x = 3, y = 4))
  expect_equal(list.mapv(x, sum(.)), c(a = 3, b = 7))

  lapply(1:3, function(i) list.mapv(x, sum(.) + i))
})

test_that("list.iter", {
  l1 <- list(1, 2, 3)
  expect_output(list.iter(l1, cat(.)), "123")
  expect_equal(list.iter(l1, {
  }), l1)
})

test_that("list.maps", {
  l1 <- list(p1 = list(x = 1, y = 2), p2 = list(x = 3, y = 4), p3 = list(x = 1,
    y = 3))
  l2 <- list(2, 3, 5)
  expect_equal(list.maps(a$x * b + a$y, a = l1, b = l2), list(p1 = 4, p2 = 13,
    p3 = 8))
  expect_equal(list.maps(..1$x * ..2 + ..1$y, l1, l2), list(p1 = 4, p2 = 13, p3 = 8))
  expect_equal(list.maps(a * b, a = list(1, 2, 3), b = list(2, 3, 4)), list(2,
    6, 12))
  expect_equal(list.maps(..1 * ..2, list(1, 2, 3), list(2, 3, 4)), list(2, 6, 12))
})

Try the rlist package in your browser

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

rlist documentation built on Sept. 5, 2021, 5:30 p.m.