2024-11-28 14:32:30 +01:00
|
|
|
library(testthat)
|
2023-02-28 13:59:45 +01:00
|
|
|
test_that("redcap_wider() returns expected output", {
|
2023-04-13 10:57:04 +02:00
|
|
|
list <-
|
|
|
|
list(
|
|
|
|
data.frame(
|
|
|
|
record_id = c(1, 2, 1, 2),
|
|
|
|
redcap_event_name = c("baseline", "baseline", "followup", "followup"),
|
|
|
|
age = c(25, 26, 27, 28)
|
|
|
|
),
|
|
|
|
data.frame(
|
|
|
|
record_id = c(1, 2),
|
|
|
|
redcap_event_name = c("baseline", "baseline"),
|
|
|
|
gender = c("male", "female")
|
|
|
|
)
|
|
|
|
)
|
|
|
|
|
|
|
|
expect_equal(
|
|
|
|
redcap_wider(list),
|
2024-11-28 14:32:30 +01:00
|
|
|
dplyr::tibble(
|
2023-04-13 10:57:04 +02:00
|
|
|
record_id = c(1, 2),
|
|
|
|
age_baseline = c(25, 26),
|
|
|
|
age_followup = c(27, 28),
|
|
|
|
gender = c("male", "female")
|
|
|
|
)
|
|
|
|
)
|
2023-02-28 13:59:45 +01:00
|
|
|
})
|
2023-03-07 15:38:28 +01:00
|
|
|
|
|
|
|
|
|
|
|
# Using test data
|
|
|
|
|
|
|
|
# Set up the path and data -------------------------------------------------
|
2023-04-13 10:57:04 +02:00
|
|
|
file_paths <- lapply(
|
2023-03-07 15:38:28 +01:00
|
|
|
c(records = "WARRIORtestForSoftwa_DATA_2018-06-21_1431.csv",
|
|
|
|
metadata = "WARRIORtestForSoftwareUpgrades_DataDictionary_2018-06-21.csv"),
|
|
|
|
get_data_location
|
|
|
|
)
|
|
|
|
|
|
|
|
redcap <- lapply(file_paths, read.csv, stringsAsFactors = FALSE)
|
2023-04-13 10:57:04 +02:00
|
|
|
redcap[["metadata"]] <- with(redcap, metadata[metadata[, 1] > "", ])
|
2023-03-07 15:38:28 +01:00
|
|
|
list <-
|
|
|
|
with(redcap, REDCap_split(records, metadata, forms = "all"))
|
|
|
|
|
|
|
|
wide_ds <- redcap_wider(list)
|
|
|
|
|
2023-04-13 10:57:04 +02:00
|
|
|
test_that("redcap_wider() returns wide output from CSV", {
|
|
|
|
expect_equal(ncol(wide_ds), 171)
|
2023-03-07 15:38:28 +01:00
|
|
|
})
|