test_that("creating and removing extra columns", { m <- mt_sim_brownian_motion() expect_silent(m[, "count"] <- 1:20) expect_identical(m$count, 1:20) expect_identical(m[(1:10) * 2, ], m[c(FALSE, TRUE), ]) expect_identical(m[, "count", drop = TRUE], 1:20) expect_s3_class(m[, "count", drop = FALSE], "move2") expect_s3_class(m[, "count"], "move2") expect_silent(m[, "count"] <- NULL) expect_false("count" %in% colnames(m)) expect_identical(nrow(mt_track_data(m[1:3, ])), 1L) expect_identical(nrow(mt_track_data(m[11:13, ])), 1L) expect_identical(nrow(mt_track_data(m[9:13, ])), 2L) expect_silent(m[, "count"] <- 1:20) expect_identical(nrow(mt_track_data(m[1:3, "count"])), 1L) expect_identical(nrow(mt_track_data(m[11:13, "count"])), 1L) expect_identical(nrow(mt_track_data(m[9:13, "count"])), 2L) expect_identical(m[1L:3L, "count", drop = TRUE], 1L:3L) expect_identical(m[11L:13L, "count", drop = TRUE], 11L:13L) expect_identical(m[9L:13L, "count", drop = TRUE], 9L:13L) }) test_that("indexing columns one bracket", { m <- mt_sim_brownian_motion() expect_named(m[c(TRUE, FALSE, FALSE)], colnames(m), ignore.order = TRUE) expect_named(m[TRUE], c("track", "time", "geometry"), ignore.order = TRUE) expect_named(m[FALSE], c("track", "time", "geometry"), ignore.order = TRUE) expect_named(m["track"], c("track", "time", "geometry"), ignore.order = TRUE) m$w <- 1.0 m$v <- 1.0 m$u <- 1L expect_named(m["v"], c("track", "time", "geometry", "v"), ignore.order = TRUE) expect_named(m[FALSE], c("track", "time", "geometry"), ignore.order = TRUE) expect_named(m[TRUE], c("u", "v", "w", "track", "time", "geometry"), ignore.order = TRUE ) expect_named(m["track"], c("track", "time", "geometry"), ignore.order = TRUE) }) test_that("assigning new column in grouped df retains class", { m <- mt_sim_brownian_motion(1L:3L, tracks = letters[5L:8L]) |> dplyr::group_by(track) old_m <- m m[, "test"] <- seq_len(nrow(m)) expect_s3_class(m, class(old_m)) expect_identical(dplyr::select(m, -test), old_m) expect_identical(m[, -which(names(m) == "test")], old_m) m[1L:3L, "test"] <- 3L:1L expect_s3_class(m, class(old_m)) expect_identical(m$test, c(3L:1L, 4L:12L)) }) test_that("check against double class assignment", { m <- mt_sim_brownian_motion() m[, "id"] <- gl(4L, 5L) expect_s3_class(mt_set_track_id(m, "id"), class(m), exact = TRUE) expect_s3_class(mt_set_track_id(dplyr::group_by(m, ("id")), "id"), class(group_by(m, "id")), exact = TRUE ) })