tests/testthat/test-readme.R

# Setup
test_dir <- file.path(tempdir(), "testing_grounds")
dir.create(test_dir)

# tests/testthat/test_parameterized_simulation.R
testthat::test_that("Simulation results are saved and read correctly", {
  # Set up parameters
  parameters_list <- list(
    iterations = 1000,
    x_dist = "rnorm",
    x_dist_options = list(n = 10, mean = 1, sd = 2),
    error_dist = "rnorm",
    error_dist_options = list(n = 10, mean = 0, sd = 1),
    beta0 = 1,
    beta1 = 1
  )

  # Run simulation
  betas <- numeric(parameters_list$iterations)
  for (i in 1:parameters_list$iterations) {
    x <- do.call(parameters_list$x_dist, parameters_list$x_dist_options)
    err <- do.call(parameters_list$error_dist, parameters_list$error_dist_options)
    y <- parameters_list$beta0 + parameters_list$beta1 * x + err
    betas[i] <- coef(lm(y ~ x))["x"]
  }

  save_objects(folder = test_dir, results = betas, parameters_list = parameters_list)

  # Check that results are saved correctly
  files <- list.files(test_dir)
  testthat::expect_true(length(files) == 2)
  testthat::expect_true(any(grepl("_parameters\\.rds$", files)))
  testthat::expect_true(any(grepl("\\.rds$", files)))
})

testthat::test_that("Results can be read back and match original", {
  # Set up parameters
  parameters_list <- list(
    iterations = 1000,
    x_dist = "rnorm",
    x_dist_options = list(n = 10, mean = 1, sd = 2),
    error_dist = "rnorm",
    error_dist_options = list(n = 10, mean = 0, sd = 1),
    beta0 = 1,
    beta1 = 1
  )

  betas <- read_objects(folder = test_dir, parameters_list = parameters_list)

  # Validate betas
  testthat::expect_true(length(betas) == parameters_list$iterations)
  testthat::expect_true(is.numeric(betas))

})

testthat::test_that("Hash table creation and cleanup works correctly", {

  # Create hash table
  hash_table <- create_hash_table(folder = test_dir)
  testthat::expect_true(nrow(hash_table) == 1)

  # Cleanup files
  cleanup_from_hash_table(folder = test_dir, hash_table = hash_table, mode = "all", request_confirmation = FALSE)

  # Validate that directory is cleaned up
  files_after_cleanup <- list.files(test_dir)
  testthat::expect_true(length(files_after_cleanup) == 0)
})

unlink(test_dir, recursive = TRUE)

Try the indexr package in your browser

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

indexr documentation built on April 12, 2025, 1:32 a.m.