inst/tinytest/test_peek_at.R

ee = expect_equal

# -----------------
# peek_at.Container
# -----------------
co = container(a = 1, 2, b = 3, 4)
ee(peek_at(co, 1), container(a = 1))
ee(peek_at(co, 2), container(2))
ee(peek_at(co, "a"), container(a = 1))
ee(peek_at(container(), 1), container())
ee(peek_at(container(), 1, .default = 0), container(0))
ee(peek_at(co, "x"), container())
ee(peek_at(co, "x", .default = 1), container(x = 1))
ee(peek_at(co, "x", "y", .default = 1), container(x = 1, y = 1))

ee(peek_at(co, "x", .default = 1:3), container(x = 1:3))
ee(peek_at(co, 1, 2, "x", "b", .default = 1:3),
   container(a = 1, 2, x = 1:3, b = 3))

ee(peek_at(co, 1:3), as.container(as.list(co)[1:3]))

ee(peek_at(co), co)
ee(peek_at(co, .default = 1), co)

# -------------
# peek_at.Dict
# ------------
d = dict(a = 1, b = 1:3)

expect_error(peek_at(d, "a", "a"), "duplicated keys")
expect_error(peek_at(d, 1, 1), "duplicated keys")
ee(peek_at(d), d)
ee(peek_at(d, NULL), dict())

ee(peek_at(d, 1:2, "x", "y"), d)

ee(peek_at(d, "b"), dict(b = 1:3))
ee(peek_at(d, "x"), dict())
ee(peek_at(d, 1), dict(a = 1))
ee(peek_at(d, 2), dict(b = 1:3))
ee(peek_at(d, "x", .default = 4:6), dict(x = 4:6))
ee(peek_at(d, 1, "x", "b", .default = 4:6),
   dict(a = 1, b = 1:3, x = 4:6))

expect_error(peek_at(d, 3, .default = 1), "all elements must be named")

ee(peek_at(d, list("a", "b", z = 9)), d)

ee(peek_at(d, list("a", "b", z = 9), .default = 9), c(d, dict(z = 9)))
# The above does not work if specified outside a list unless default is NULL
expect_error(peek_at(d, "a", "b", z = 9, .default = 9),
             "all elements must be named")
ee(peek_at(d, "a", "b", z = 9), d)

# ------------------
# peek_at.dict.table
# ------------------
dit = dict.table(a = 1:3, b = 4:6)

expect_error(peek_at(dit, "a", "a"), "duplicated keys")
expect_error(peek_at(dit, 1, 1), "duplicated keys")
ee(peek_at(dit), dit)
ee(peek_at(dit, NULL), dict.table())

ee(peek_at(dit, 1:2, "x", "y"), dit)
ee(peek_at(dit, "a"), dict.table(a = 1:3))
ee(peek_at(dit, 1), dict.table(a = 1:3))

ee(peek_at(dit, 3), dict.table())
ee(peek_at(dit, "x"), dict.table())

ee(peek_at(dit, "x", .default = 0), dict.table(x = rep(0, nrow(dit))))

ee(peek_at(dit, "a", "x", .default = 0),
   dict.table(a = 1:3, x = rep(0, nrow(dit))))

ee(peek_at(dit, 1, "x", "b", .default = 0),
   cbind(dit, dict.table(x = c(0, 0, 0))))

ee(peek_at(dit, list(x = 9)), dict.table())
ee(peek_at(dit, list(x = 9), .default = -1), dict.table(x = rep(-1, 3)))
ee(peek_at(dit, list(x = "a")), dit[, 1])

ee(peek_at(dit, list("a", "b", z = 9), .default = 9),
   cbind(dit, dict.table(z = c(9, 9, 9))))
# The above does not work if specified outside a list unless default is NULL
expect_error(peek_at(dit, "a", "b", z = 9, .default = 9),
             "all elements must be named")
ee(peek_at(dit, "a", "b", z = 9), dit)

suppressWarnings({
    ee(peek_at(dit, "x", .default = 1:2), dict.table(x = c(1, 2, 1)))
})
expect_warning(peek_at(dit, "x", .default = 1:2),
               "did not match number of rows")
rpahl/container documentation built on Nov. 10, 2023, 6:31 p.m.