tests/testthat/test-calculate_average.R

# create test data frame
df <- data.frame(
    week_payment1 = c(1, 2, 3),
    week_payment2 = c(4, 5, 6),
    week_payment3 = c(7, 8, 9),
    other_column = c(10, 11, 12)
    )

# test for df is not a data frame
test_that("calculate_average() errors when df is not a data frame", {
  df <- 1
  expect_error(calculate_average(df, "week_payment"))
})

# test for pattern is not a character
test_that("calculate_average() errors when pattern is not a character", {
  expect_error(calculate_average(df, 1))
})

# test for pattern is not found
test_that("calculate_average() errors when pattern not found", {
  expect_error(calculate_average(df, "no_matching_pattern"))
})

# test for return type
test_that("calculate_average() returns a numeric vector", {
  result <- calculate_average(df, "week_payment")
  expect_type(result, "double")
})

# test for data frame with only 1 column
test_that("calculate_average() returns correct value", {
  df <- data.frame(
    week_payment1 = c(1, 2, 3)
    )
  result <- calculate_average(df, "week_payment")
  expect_equal(result, c(1, 2, 3))
})

# test for data frame with only 1 row
test_that("calculate_average() returns correct value", {
  df <- data.frame(
    week_payment1 = c(1)
    )
  result <- calculate_average(df, "week_payment")
  expect_equal(result, c(1))
})

# test for return correct value
test_that("calculate_average() returns correct average", {
  result <- calculate_average(df, "week_payment")
  expect_equal(result, c(4, 5, 6))
})
UBC-MDS/featurescreator documentation built on Feb. 5, 2022, 8:12 a.m.