tests/testthat/test-f_select.R

test_that("selecting", {
  expect_equal(f_select(iris),
                         dplyr::select(iris))
  expect_equal(f_select(iris, NULL),
                         dplyr::select(iris, NULL))
  expect_equal(f_select(iris, .cols = character(0)),
                         dplyr::select(iris, all_of(character(0))))
  expect_equal(f_select(iris, .cols = integer(0)),
                         dplyr::select(iris, all_of(character(0))))
  expect_equal(f_select(iris, dplyr::any_of(c("ok", names(iris)))),
                         dplyr::select(iris, dplyr::any_of(c("ok", names(iris)))))
  expect_error(f_select(iris, dplyr::all_of(c("ok", names(iris)))))
  expect_equal(f_select(iris, dplyr::any_of(c("okay", "Species"))),
                         dplyr::select(iris, dplyr::any_of(c("okay", "Species"))))
  expect_error(f_select(iris, dplyr::all_of(c("okay", "Species"))))
  expect_equal(f_select(iris, dplyr::all_of(rev(names(iris)))),
                         dplyr::select(iris, dplyr::all_of(rev(names(iris)))))

  expect_equal(f_select(iris, c("okay" = 3, 3, 4)),
                         dplyr::select(iris, c("okay" = 3, 3, 4)))
  expect_equal(f_select(iris, c(3, "okay" = 3, 4)),
                         dplyr::select(iris, c(3, "okay" = 3, 4)))

  expect_equal(f_select(iris, c(1, NULL, "okay" = "Species", "Sepal.Width")),
                         dplyr::select(iris, c(1, NULL, "okay" = "Species", "Sepal.Width")))

  iris2 <- dplyr::group_by(iris, Sepal.Length, Species)

  expect_equal(f_select(iris2),
                         dplyr::select(iris2))
  expect_equal(f_select(iris2, NULL),
                         dplyr::select(iris2, NULL))
  expect_equal(f_select(iris2, dplyr::any_of(c("okay", "Species"))),
                         dplyr::select(iris2, dplyr::any_of(c("okay", "Species"))))
  expect_error(f_select(iris2, dplyr::all_of(c("okay", "Species"))))
  expect_equal(f_select(iris2, dplyr::all_of(rev(names(iris2)))),
                         dplyr::select(iris2, dplyr::all_of(rev(names(iris2)))))

  expect_equal(f_select(iris2, c("okay" = 3, 3, 4)),
                         dplyr::select(iris2, c("okay" = 3, 3, 4)))
  expect_equal(f_select(iris2, c(3, "okay" = 3, 4)),
                         dplyr::select(iris2, c(3, "okay" = 3, 4)))

  expect_equal(f_select(iris2, c(1, NULL, "okay" = "Species", "Sepal.Width")),
                         dplyr::select(iris2, c(1, NULL, "okay" = "Species", "Sepal.Width")))

  expect_equal(f_select(iris2, okay = Species, ok2 = Sepal.Length),
                         dplyr::select(iris2, okay = Species, ok2 = Sepal.Length))
})


test_that("renaming", {
  expect_equal(f_rename(iris), iris)
  expect_equal(f_rename(iris, .cols = 0), iris)

  expect_equal(f_rename(iris, .cols = c("okay" = "Species")),
               dplyr::rename(iris, okay = Species))

  expect_equal(f_rename(dplyr::group_by(iris, Species), .cols = c("okay" = "Species")),
               dplyr::rename(dplyr::group_by(iris, Species), okay = Species))
})

Try the fastplyr package in your browser

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

fastplyr documentation built on June 8, 2025, 11:18 a.m.