Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Fixes and testing extreme templates #968

Merged
merged 8 commits into from
Dec 6, 2024
Merged
Show file tree
Hide file tree
Changes from 2 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
31 changes: 26 additions & 5 deletions R/tt_as_df.R
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,12 @@ as_result_df <- function(tt, spec = NULL,
which_root_name = c("root", "rbind_root"),
all = TRUE
)

# Correcting maxlen for even number of paths (only multianalysis diff table names)
maxlen <- max(lengths(df$path))
if (maxlen %% 2 != 0) {
maxlen <- maxlen + 1
}

# Loop for metadata (path and details from make_row_df)
metadf <- do.call(
Expand Down Expand Up @@ -174,6 +179,7 @@ as_result_df <- function(tt, spec = NULL,
ret <- rbind(header_colnames_matrix, ret)
}

# make_ard -----------------------------------------------------------------
# ARD part for one stat per row
if (make_ard) {
cinfo_df <- col_info(tt)
Expand Down Expand Up @@ -238,11 +244,13 @@ as_result_df <- function(tt, spec = NULL,
stat_name <- setNames(cell_stat_names[, col_i - min(only_col_indexes) + 1, drop = TRUE], NULL)
stat <- setNames(ret_tmp[!col_label_rows, col_i, drop = TRUE], NULL)
necessary_stat_lengths <- sapply(stat, length)
stat[sapply(stat, is.null)] <- NA

# Truncating or adding NA if stat names has more or less elements than stats
stat_name <- lapply(seq_along(stat_name), function(sn_i) {
stat_name[[sn_i]][seq_len(necessary_stat_lengths[sn_i])]
})
stat_name[sapply(stat_name, function(x) length(x) == 0)] <- NA
Melkiades marked this conversation as resolved.
Show resolved Hide resolved

# unnesting stat_name and stat
tmp_ret_by_col_i <- NULL
Expand Down Expand Up @@ -322,7 +330,15 @@ as_result_df <- function(tt, spec = NULL,
kids <- tree_children(ci_coltree)
return(lapply(kids, .get_column_split_name))
}
sapply(pos_splits(tree_pos(ci_coltree)), spl_payload)

lapply(pos_splits(tree_pos(ci_coltree)), function(x) {
pl <- spl_payload(x)
if (!is.null(pl)) { # it is null when all obs (1 column)
return(pl)
} else {
return(x@name)
}
})
}

# Function that selects specific outputs from the result data frame
Expand Down Expand Up @@ -378,6 +394,9 @@ do_label_row <- function(rdfrow, maxlen) {
# Special cases with hidden labels
if (length(pth) %% 2 == 1) {
extra_nas_from_splits <- extra_nas_from_splits + 1
} else {
pth <- c("<analysis_spl_tbl_name>", pth)
extra_nas_from_splits <- extra_nas_from_splits - 1
}

c(
Expand Down Expand Up @@ -415,15 +434,17 @@ do_content_row <- function(rdfrow, maxlen) {
do_data_row <- function(rdfrow, maxlen) {
pth <- rdfrow$path[[1]]
pthlen <- length(pth)
## odd means we have a multi-analsysis step in the path, we dont' want that in the result data frame
## odd means we have a multi-analsysis step in the path, we do not want this in the result
if (pthlen %% 2 == 1) {
pth <- pth[-1 * (pthlen - 2)]
# we remove the last element, as it is a fake split (tbl_name from analyse)
# pth <- pth[-1 * (pthlen - 2)]
pth <- c("<analysis_spl_tbl_name>", pth)
}
pthlen_new <- length(pth)
if (maxlen == 1) pthlen_new <- 3
if (maxlen == 1) pthlen_new <- 3 # why?
c(
as.list(pth[seq_len(pthlen_new - 2)]),
replicate(maxlen - pthlen, list(NA_character_)),
replicate(ifelse((maxlen - pthlen_new) > 0, maxlen - pthlen_new, 0), list(NA_character_)),
as.list(tail(pth, 2)),
list(
label_name = rdfrow$label,
Expand Down
10 changes: 10 additions & 0 deletions tests/testthat/test-result_data_frame.R
Original file line number Diff line number Diff line change
Expand Up @@ -239,6 +239,16 @@ test_that("as_result_df works fine with empty tables and no character(0) is allo
)
})

test_that("as_result_df works with only analyze tables (odd num of path elements)", {
Melkiades marked this conversation as resolved.
Show resolved Hide resolved
tbl <- basic_table() %>%
analyze("cyl", table_names = "a") %>%
analyze("mpg") %>%
build_table(mtcars)

expect_equal(as_result_df(tbl)$group1[[1]], "<analysis_spl_tbl_name>")
expect_equal(as_result_df(tbl, make_ard = TRUE)$group1[[1]], "<analysis_spl_tbl_name>")
})

test_that("make_ard produces realistic ARD output with as_result_df", {
# Testing fundamental getters/setters
rc <- rcell(c(1, 2), stat_names = c("Rand1", "Rand2"))
Expand Down
Loading