test_that("add_data_table() writes over tables", {
overwrite_table_error <- "Cannot overwrite existing table with another table"
df1 <- data.frame("X" = 1:10)
wb <- wb_add_worksheet(wb_workbook(), "Sheet1")
## table covers rows 4->10 and cols 4->8
wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 4)
## should all run without error
wb$add_data_table(sheet = 1, x = df1, start_col = 3, start_row = 2)
wb$add_data_table(sheet = 1, x = df1, start_col = 9, start_row = 2)
wb$add_data_table(sheet = 1, x = df1, start_col = 4, start_row = 11)
wb$add_data_table(sheet = 1, x = df1, start_col = 5, start_row = 11)
wb$add_data_table(sheet = 1, x = df1, start_col = 6, start_row = 11)
wb$add_data_table(sheet = 1, x = df1, start_col = 7, start_row = 11)
wb$add_data_table(sheet = 1, x = df1, start_col = 8, start_row = 11)
wb$add_data_table(sheet = 1, x = head(iris, 2), start_col = 4, start_row = 1)
## Now error
expect_error(wb$add_data_table(sheet = 1, x = df1, start_col = "H", start_row = 21), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = df1, start_col = 3, start_row = 12), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = df1, start_col = 9, start_row = 12), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = df1, start_col = "i", start_row = 12), regexp = overwrite_table_error)
## more errors
expect_error(wb$add_data_table(sheet = 1, x = head(iris)), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 21), regexp = overwrite_table_error)
## should work
wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 22)
wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 40)
## more errors
expect_error(wb$add_data_table(sheet = 1, x = head(iris, 2), start_col = 4, start_row = 38), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = head(iris, 2), start_col = 4, start_row = 38, col_names = FALSE), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = head(iris), start_col = "H", start_row = 40), regexp = overwrite_table_error)
wb$add_data_table(sheet = 1, x = head(iris), start_col = "I", start_row = 40)
wb$add_data_table(sheet = 1, x = head(iris)[, 1:3], start_col = "A", start_row = 40)
expect_error(wb$add_data_table(sheet = 1, x = head(iris, 2), start_col = 4, start_row = 38, col_names = FALSE), regexp = overwrite_table_error)
expect_error(wb$add_data_table(sheet = 1, x = head(iris, 2), start_col = 1, start_row = 46, col_names = FALSE), regexp = overwrite_table_error)
})
test_that("zero row data table works", {
wb <- wb_workbook() %>%
wb_add_worksheet()
expect_warning(
wb$add_data_table(x = data.frame(a = NA, b = NA)[0, ]),
"Found data table with zero rows, adding one. Modify na with na.strings"
)
exp <- "A1:B2"
got <- wb$tables$tab_ref
expect_equal(exp, got)
})
test_that("write_data over tables", {
overwrite_table_error <- "Cannot overwrite table headers. Avoid writing over the header row"
df1 <- data.frame("X" = 1:10)
wb <- wb_add_worksheet(wb_workbook(), "Sheet1")
## table covers rows 4->10 and cols 4->8
wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 4)
## Anywhere on row 5 is fine
for (i in 1:10) {
wb$add_data(sheet = 1, x = head(iris), start_row = 5, start_col = i)
}
## Anywhere on col i is fine
for (i in 1:10) {
wb$add_data(sheet = 1, x = head(iris), start_row = i, start_col = "i")
}
## Now errors on headers
expect_error(wb$add_data(sheet = 1, x = head(iris), start_col = 4, start_row = 4), regexp = overwrite_table_error)
wb$add_data(sheet = 1, x = head(iris), start_col = 4, start_row = 5)
wb$add_data(sheet = 1, x = head(iris)[1:3])
wb$add_data(sheet = 1, x = head(iris, 2), start_col = 4)
wb$add_data(sheet = 1, x = head(iris, 2), start_col = 4, col_names = FALSE)
## Example of how this should be used
wb$add_data_table(sheet = 1, x = head(iris), start_col = 4, start_row = 30)
wb$add_data(sheet = 1, x = head(iris), start_col = 4, start_row = 31, col_names = FALSE)
wb$add_data_table(sheet = 1, x = head(iris), start_col = 10, start_row = 30)
wb$add_data(sheet = 1, x = tail(iris), start_col = 10, start_row = 31, col_names = FALSE)
wb$add_data_table(sheet = 1, x = head(iris)[, 1:3], start_col = 1, start_row = 30)
wb$add_data(sheet = 1, x = tail(iris), start_col = 1, start_row = 31, col_names = FALSE)
})
test_that("Validate Table Names", {
wb <- wb_add_worksheet(wb_workbook(), "Sheet 1")
## case
expect_equal(wb_validate_table_name(wb, "test"), "test")
expect_equal(wb_validate_table_name(wb, "TEST"), "test")
expect_equal(wb_validate_table_name(wb, "Test"), "test")
## length
expect_error(wb_validate_table_name(wb, paste(sample(LETTERS, size = 300, replace = TRUE), collapse = "")), regexp = "`table_name` must be less than 255 characters")
## look like cell ref
expect_error(wb_validate_table_name(wb, "R1C2"), regexp = "`table_name` cannot be the same as a cell reference, such as R1C1", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "A1"), regexp = "`table_name` cannot be the same as a cell reference", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "R06821C9682"), regexp = "`table_name` cannot be the same as a cell reference, such as R1C1", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "ABD918751"), regexp = "`table_name` cannot be the same as a cell reference", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "A$100"), regexp = "`table_name` cannot contain spaces or the '$' character", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "A12$100"), regexp = "`table_name` cannot contain spaces or the '$' character", fixed = TRUE)
tbl_nm <- "性別"
expect_equal(wb_validate_table_name(wb, tbl_nm), tbl_nm)
})
test_that("Existing Table Names", {
wb <- wb_add_worksheet(wb_workbook(), "Sheet 1")
## Existing names - case in-sensitive
wb$add_data_table(sheet = 1, x = head(iris), table_name = "Table1")
expect_error(wb_validate_table_name(wb, "Table1"), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
expect_error(wb$add_data_table(sheet = 1, x = head(iris), table_name = "Table1", start_col = 10), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "TABLE1"), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
expect_error(wb$add_data_table(sheet = 1, x = head(iris), table_name = "TABLE1", start_col = 20), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
expect_error(wb_validate_table_name(wb, "table1"), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
expect_error(wb$add_data_table(sheet = 1, x = head(iris), table_name = "table1", start_col = 30), regexp = "`table_name = 'table1'` already exists", fixed = TRUE)
})
test_that("custom table styles work", {
# at the moment we have no interface to add custom table styles
wb <- wb_workbook() %>%
wb_add_worksheet()
# create dxf elements to be used in the table style
tabCol1 <- create_dxfs_style(bg_fill = wb_color(theme = 7))
tabCol2 <- create_dxfs_style(bg_fill = wb_color(theme = 5))
tabBrd1 <- create_dxfs_style(border = TRUE)
tabCol3 <- create_dxfs_style(bg_fill = wb_color(hex = "FFC00000"), font_color = wb_color("white"))
# don't forget to assign them to the workbook
wb$add_style(tabCol1)
wb$add_style(tabCol2)
wb$add_style(tabBrd1)
wb$add_style(tabCol3)
# tweak a working style with 4 elements
tab_xml <- sprintf(
"
",
length(c(tabCol1, tabCol2, tabCol3, tabBrd1)),
wb$styles_mgr$get_dxf_id("tabBrd1"),
wb$styles_mgr$get_dxf_id("tabCol3"),
wb$styles_mgr$get_dxf_id("tabCol1"),
wb$styles_mgr$get_dxf_id("tabCol2")
)
wb$add_style(tab_xml)
expect_silent(wb$add_data_table(x = mtcars, table_style = "RedTableStyle"))
wb$add_worksheet()
expect_error(wb$add_data_table(x = mtcars, table_style = "RedTableStyle1"), "Invalid table style.")
})
test_that("updating table works", {
wb <- wb_workbook()
wb$add_worksheet()$add_data_table(x = mtcars)
wb$add_worksheet()$add_data_table(x = mtcars[1:2])
wb_to_df(wb, named_region = "Table2")
wb$add_data(dims = "C1", x = mtcars[-1:-2], name = "test")
wb <- wb_update_table(wb, "Table2", sheet = 2, dims = "A1:J4")
exp <- mtcars[1:3, 1:10]
got <- wb_to_df(wb, named_region = "Table2")
expect_equal(exp, got, ignore_attr = TRUE)
wb <- wb_workbook()$add_worksheet()$add_data_table(x = mtcars, with_filter = FALSE)
wb$update_table(tabname = "Table1", dims = "A1:J4")
got <- wb$tables$tab_ref
expect_equal(got, "A1:J4")
})
test_that("writing table headers with factor variables works", {
df <- data.frame(
fct = structure(
1:2,
levels = c(
"one",
"two"
),
class = "factor"),
`1` = 1:2,
check.names = FALSE
)
wb <- wb_workbook()$add_worksheet()$add_data_table(x = df)
exp <- "1"
got <- wb$worksheets[[1]]$sheet_data$cc$is[[2]]
expect_equal(exp, got)
})
test_that("tables cannot have duplicated column names", {
df1 <- data.frame(
x = 1,
x = 2,
check.names = FALSE
)
df2 <- data.frame(
x = 1,
X = 2,
check.names = FALSE
)
wb <- wb_workbook()
expect_warning(wb$add_worksheet()$add_data_table(x = df1), "tables cannot have duplicated column names")
expect_warning(wb$add_worksheet()$add_data_table(x = df2), "tables cannot have duplicated column names")
exp <- c("", "")
got <- xml_node(wb$tables$tab_xml[[1]], "table", "tableColumns", "tableColumn")
expect_equal(exp, got)
exp <- c("", "")
got <- xml_node(wb$tables$tab_xml[[2]], "table", "tableColumns", "tableColumn")
expect_equal(exp, got)
})
test_that("make sure that table id is unique", {
tmp <- temp_xlsx()
wb <- write_xlsx(x = list(head(mtcars), head(iris)), as_table = TRUE)
wb$remove_tables(sheet = 1, table = "Table1", remove_data = FALSE)
wb$save(tmp)
wb <- wb_load(tmp)
wb$add_worksheet()$add_data_table(x = head(Orange))
exp <- data.frame(name = c("Table2", "Table3"), id = c("2", "3"), stringsAsFactors = FALSE)
got <- rbindlist(xml_attr(wb$tables$tab_xml, "table"))[c("name", "id")]
expect_equal(exp, got)
})
test_that("wb_get_named_regions, works with removed tables", {
wb <- wb_workbook()$
add_worksheet()$add_data_table(x = iris, table_name = "iris1")$
add_worksheet()$add_data_table(x = iris, table_name = "iris2")$
add_worksheet()$add_data_table(x = iris, table_name = "iris3")
wb$remove_tables(table = "iris3")
tabs <- wb$get_named_regions(tables = TRUE)
expect_equal(2, nrow(tabs))
expect_equal(paste0("iris", 1:2), tabs$name)
})
test_that("reading tables from file works", {
tmp <- temp_xlsx()
exp <- head(mtcars)
write_xlsx(x = exp, file = tmp, as_table = TRUE)
got <- wb_to_df(tmp, named_region = "Table1")
expect_equal(exp, got, ignore_attr = TRUE)
})