inst/tinytest/test_Ops-replace.R

ee = expect_equal

# ----------------------
# Container [<- operator
# ----------------------
co = container(a = 1, b = "bar")
co[1:2] <- 1:2
ee(co, container(a = 1, b = 2))
expect_error(co[3] <- 3, "index out of range")

co[list(1, "b")] <- 3:4
ee(co, container(a = 3, b = 4))

co[1:2] <- 0
ee(co, container(a = 0, b = 0))

co <- container(1, 2, 3)
expect_warning(co[1:3] <- 1:2, "number of items to replace")
ee(co, container(1, 2, 1))
expect_warning(co[1] <- 5:6, "number of items to replace")
ee(co, container(5, 2, 1))

# -----------------------
# Container [[<- operator
# -----------------------
co = container(a = 1, b = "bar")
co[[1]] <- 2
ee(co, container(a = 2, b = "bar"))
co[[2]] <- 9
ee(co, container(a = 2, b = 9))

co[["b"]] <- 0
co[["x"]] <- 0
ee(co, container(a = 2, b = 0, x = 0))
expect_error(co[[4]] <- 1, "index out of range")

co[[{2}]] <- 1:4
ee(co, container(a = 1:4, b = 0, x = 0))

co[[{1:4}]] <- NA
ee(co, container(a = NA, b = 0, x = 0))

co[[{NA}]] <- NULL
ee(co, container(a = NULL, b = 0, x = 0))

co[[{0}]] <- list(1, "a")
ee(co, container(a = NULL, b = list(1, "a"), x = 0))

co[[{list(1, "a")}]] <- 9
ee(co, container(a = NULL, b = 9, x = 0))

expect_error(co[[{1}]] <- 9, "old element \\(1\\) is not in Container")
expect_error(co[[1, 2]] <- 3:4)
expect_error(co[[1:2]] <- 3:4, "index must be of length 1")

# ----------------------
# Container $<- operator
# ----------------------
co = container(a = 1, b = "bar")
co$f <- 3
ee(co, container(a = 1, b = "bar", f = 3))
co$b <- 2
ee(co, container(a = 1, b = 2, f = 3))

co$`x 2` <- 0
ee(co[["x 2"]], 0)
rpahl/container documentation built on Nov. 10, 2023, 6:31 p.m.