tests/testthat/test-rows-dimensions.R

context("dummy_rows returns proper dimensions")

load(system.file("testdata", "fastDummies_data.rda",
                 package = "fastDummies"))


test_that("dummy_rows returns same number of columns as inputted", {
  expect_equal(ncol(dummy_rows(no_dummies_needed)),
               ncol(no_dummies_needed))
  expect_equal(ncol(dummy_rows(fastDummies_example)),
               ncol(fastDummies_example))
  expect_equal(ncol(dummy_rows(crime)), ncol(crime))

  expect_equal(ncol(dummy_rows(no_dummies_needed_DT)),
               ncol(no_dummies_needed_DT))
  expect_equal(ncol(dummy_rows(fastDummies_example_DT)),
               ncol(fastDummies_example_DT))
  expect_equal(ncol(dummy_rows(crime_DT)), ncol(crime_DT))

  expect_equal(ncol(dummy_rows(no_dummies_needed_tibble)),
               ncol(no_dummies_needed_tibble))
  expect_equal(ncol(dummy_rows(fastDummies_example_tibble)),
               ncol(fastDummies_example_tibble))
  expect_equal(ncol(dummy_rows(crime_tibble)), ncol(crime_tibble))

  # With dummy_indicator TRUE
  expect_equal(ncol(dummy_rows(no_dummies_needed,
                               dummy_indicator = TRUE)),
               ncol(no_dummies_needed) + 1)
  expect_equal(ncol(dummy_rows(fastDummies_example,
                               dummy_indicator = TRUE)),
               ncol(fastDummies_example) + 1)
  expect_equal(ncol(dummy_rows(crime, dummy_indicator = TRUE)),
               ncol(crime) + 1)

  expect_equal(ncol(dummy_rows(no_dummies_needed_DT,
                               dummy_indicator = TRUE)),
               ncol(no_dummies_needed_DT) + 1)
  expect_equal(ncol(dummy_rows(fastDummies_example_DT,
                               dummy_indicator = TRUE)),
               ncol(fastDummies_example_DT) + 1)
  expect_equal(ncol(dummy_rows(crime_DT, dummy_indicator = TRUE)),
               ncol(crime_DT) + 1)

  expect_equal(ncol(dummy_rows(no_dummies_needed_tibble,
                               dummy_indicator = TRUE)),
               ncol(no_dummies_needed_tibble) + 1)
  expect_equal(ncol(dummy_rows(fastDummies_example_tibble,
                               dummy_indicator = TRUE)),
               ncol(fastDummies_example_tibble) + 1)
  expect_equal(ncol(dummy_rows(crime_tibble, dummy_indicator = TRUE)),
               ncol(crime_tibble) + 1)
})

test_that("Number of rows is as expected", {
  expect_equal(nrow(dummy_rows(no_dummies_needed)), 4)
  expect_equal(nrow(dummy_rows(fastDummies_example)), 8)
  expect_equal(nrow(dummy_rows(crime)), 3)
  expect_equal(nrow(dummy_rows(crime,
                               select_columns = c("city", "year"))), 4)

  expect_equal(nrow(dummy_rows(no_dummies_needed_DT)), 4 )
  expect_equal(nrow(dummy_rows(fastDummies_example_DT)), 8)
  expect_equal(nrow(dummy_rows(crime_DT)),       3)
  expect_equal(nrow(dummy_rows(crime_DT,
                               select_columns = c("city", "year"))), 4)

  expect_equal(nrow(dummy_rows(no_dummies_needed_tibble)), 4 )
  expect_equal(nrow(dummy_rows(fastDummies_example_tibble)), 8)
  expect_equal(nrow(dummy_rows(crime_tibble)),       3)
  expect_equal(nrow(dummy_rows(crime_tibble,
                               select_columns = c("city", "year"))), 4)

  # With dummy_indicator TRUE
  expect_equal(nrow(dummy_rows(no_dummies_needed,
                               dummy_indicator = TRUE)), 4)
  expect_equal(nrow(dummy_rows(fastDummies_example,
                               dummy_indicator = TRUE)), 8)
  expect_equal(nrow(dummy_rows(crime, dummy_indicator = TRUE)), 3)
  expect_equal(nrow(dummy_rows(crime, dummy_indicator = TRUE,
                               select_columns = c("city", "year"))), 4)

  expect_equal(nrow(dummy_rows(no_dummies_needed_DT,
                               dummy_indicator = TRUE)), 4)
  expect_equal(nrow(dummy_rows(fastDummies_example_DT,
                               dummy_indicator = TRUE)), 8)
  expect_equal(nrow(dummy_rows(crime_DT, dummy_indicator = TRUE)), 3)
  expect_equal(nrow(dummy_rows(crime_DT, dummy_indicator = TRUE,
                               select_columns = c("city", "year"))), 4)

  expect_equal(nrow(dummy_rows(no_dummies_needed_tibble,
                               dummy_indicator = TRUE)), 4)
  expect_equal(nrow(dummy_rows(fastDummies_example_tibble,
                               dummy_indicator = TRUE)), 8)
  expect_equal(nrow(dummy_rows(crime_tibble, dummy_indicator = TRUE)), 3)
  expect_equal(nrow(dummy_rows(crime_tibble, dummy_indicator = TRUE,
                               select_columns = c("city", "year"))), 4)


})

Try the fastDummies package in your browser

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

fastDummies documentation built on Sept. 11, 2024, 8:07 p.m.