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

712 - {shinytest2} for tm_a_pca #716

Merged
merged 31 commits into from
Apr 22, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
31 commits
Select commit Hold shift + click to select a range
d2d4e1a
feat: support for e2e tests in PCA module
averissimo Apr 10, 2024
a20da5a
fix: remove app view expressions
averissimo Apr 10, 2024
a1a0c94
e2e feat: add remaining data extract input
averissimo Apr 10, 2024
5fb8885
fix: linter errors
averissimo Apr 11, 2024
08292fd
fix: adds ggplot2 prefix to all calls
averissimo Apr 11, 2024
7ebe92a
fix: adds prefix to missing vars() call
averissimo Apr 11, 2024
3cbee3f
fix: remove requirement for loading shinytest2 and adds wait
averissimo Apr 11, 2024
ebb00eb
Apply suggestions from code review
averissimo Apr 11, 2024
e5c3783
feat: move app driver initialization to helper
averissimo Apr 11, 2024
f578c62
feat: split complex test into smaller tests
averissimo Apr 11, 2024
119db66
chore: rename helper name
averissimo Apr 12, 2024
59594fd
chore: remove wait_for_idle as it was implementd upstream
averissimo Apr 12, 2024
e7d14b5
fix: rename missing instances
averissimo Apr 12, 2024
c5fe9e5
fix: missing _driver on call
averissimo Apr 12, 2024
1791583
fix: move helper to test file
averissimo Apr 15, 2024
c7af8ca
adds some expect_no_validation_error
averissimo Apr 15, 2024
4356c72
docs: revert prefixes
averissimo Apr 17, 2024
2abbd29
chore: revert multiline to single line
averissimo Apr 17, 2024
65eab4e
chore: revert change in comment
averissimo Apr 17, 2024
a51e745
Apply suggestions from @m7pr on `set_active_module_input` rename
averissimo Apr 17, 2024
30a6330
Merge branch 'main' into 712-tm_a_pca@main
averissimo Apr 17, 2024
ce2a06e
fix: replace TealAppDriver with init_teal_app_driver
averissimo Apr 17, 2024
98751d4
Update tests/testthat/test-shinytest2-tm_a_pca.R
averissimo Apr 18, 2024
01b4b3b
chore: split tests into multiple
averissimo Apr 18, 2024
f25df6e
docs: adds a simple comment
averissimo Apr 18, 2024
1428f58
fix: wrong expectation
averissimo Apr 18, 2024
b3b2c18
Merge branch 'main' into 712-tm_a_pca@main
averissimo Apr 18, 2024
8f863fe
Merge branch 'main' into 712-tm_a_pca@main
m7pr Apr 19, 2024
e8a5acc
Merge branch 'main' into 712-tm_a_pca@main
averissimo Apr 19, 2024
7099007
Merge branch 'main' into 712-tm_a_pca@main
averissimo Apr 19, 2024
aa9d18c
Merge branch 'main' into 712-tm_a_pca@main
averissimo Apr 22, 2024
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
2 changes: 1 addition & 1 deletion R/tm_a_pca.R
Original file line number Diff line number Diff line change
Expand Up @@ -264,7 +264,7 @@ ui_a_pca <- function(id, ...) {
collapsed = TRUE,
conditionalPanel(
condition = sprintf(
"input['%s'] == 'Elbow Plot' || input['%s'] == 'Eigenvector plot'",
"input['%s'] == 'Elbow plot' || input['%s'] == 'Eigenvector plot'",
ns("plot_type"),
ns("plot_type")
),
Expand Down
245 changes: 245 additions & 0 deletions tests/testthat/test-shinytest2-tm_a_pca.R
Original file line number Diff line number Diff line change
@@ -0,0 +1,245 @@
app_driver_tm_a_pca <- function() {
# Dataset only used once
data <- within(teal.data::teal_data(), {
require(nestcolor)

USArrests <- USArrests # nolint: object_name.
})
teal.data::datanames(data) <- "USArrests"


init_teal_app_driver(
data = data,
modules = tm_a_pca(
dat = teal.transform::data_extract_spec(
dataname = "USArrests",
select = teal.transform::select_spec(
choices = teal.transform::variable_choices(
data = data[["USArrests"]],
c("Murder", "Assault", "UrbanPop", "Rape")
),
selected = c("Murder", "Assault"),
multiple = TRUE
)
),
size = c(3, 1, 5),
alpha = c(.5, 0, 1),
font_size = c(10, 8, 15),
ggtheme = "light",
rotate_xaxis_labels = TRUE,
pre_output = shiny::tags$div(id = "unique_id_pre", "A pre output"),
post_output = shiny::tags$div(id = "unique_id_post", "A post output")
)
)
}

# Defaults --------------------------------------------------------------------

testthat::test_that("e2e - tm_a_pca: module is initialised with the specified defaults in function call", {
averissimo marked this conversation as resolved.
Show resolved Hide resolved
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()

app_driver$expect_no_shiny_error()

testthat::expect_setequal(
app_driver$get_active_module_input("dat-dataset_USArrests_singleextract-select"),
c("Murder", "Assault")
)

module_parent_id <- gsub("-module$", "", app_driver$active_module_ns())
testthat::expect_equal(app_driver$get_text(sprintf("#%s %s", module_parent_id, "#unique_id_pre")), "A pre output")
testthat::expect_equal(app_driver$get_text(sprintf("#%s %s", module_parent_id, "#unique_id_post")), "A post output")

# Plot options that can be changed in call
testthat::expect_true(app_driver$get_active_module_input("rotate_xaxis_labels"))
testthat::expect_equal(app_driver$get_active_module_input("ggtheme"), "light")
testthat::expect_equal(app_driver$get_active_module_input("font_size"), 10)

app_driver$stop()
})

# Data extract ----------------------------------------------------------------

testthat::test_that("e2e - tm_a_pca: Eigenvector table should have data extract selection Murder/Assault on header", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()

# Data selection (adds rows to tables)
app_driver$set_active_module_input("dat-dataset_USArrests_singleextract-select", c("Murder", "Assault"), wait = FALSE)
app_driver$expect_no_validation_error()

testthat::expect_match(app_driver$get_active_module_output("tbl_eigenvector"), "Assault")
testthat::expect_match(app_driver$get_active_module_output("tbl_eigenvector"), "Murder")

testthat::expect_no_match(app_driver$get_active_module_output("tbl_eigenvector"), "UrbanPop")
})

testthat::test_that("e2e - tm_a_pca: Eigenvector table should have data extract selection Murder/UrbanPop on header", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()

app_driver$set_active_module_input("plot_type", "Circle plot")

app_driver$set_active_module_input("dat-dataset_USArrests_singleextract-select", c("Murder", "UrbanPop"))
app_driver$expect_no_validation_error()

testthat::expect_match(app_driver$get_active_module_output("tbl_eigenvector"), "UrbanPop")
averissimo marked this conversation as resolved.
Show resolved Hide resolved
testthat::expect_match(app_driver$get_active_module_output("tbl_eigenvector"), "Murder")
testthat::expect_no_match(app_driver$get_active_module_output("tbl_eigenvector"), "Assault")
})

testthat::test_that("e2e - tm_a_pca: Color by columns (data_extract) must be from non-selected variable set", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()

app_driver$set_active_module_input("plot_type", "Biplot")

# Change colors of data points
app_driver$set_active_module_input("response-dataset_USArrests_singleextract-select", c("UrbanPop"))
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("response-dataset_USArrests_singleextract-select", c("Murder"))
app_driver$expect_validation_error()

app_driver$stop()
})

# Encodings -------------------------------------------------------------------

testthat::test_that("e2e - tm_a_pca: Changing output encodings of tables_display does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# Display section (hides tables)

app_driver$set_active_module_input("tables_display", c())
app_driver$expect_no_validation_error()

# Tables are removed from DOM (output should generate a silent error empty message)
testthat::expect_type(app_driver$get_active_module_output("tbl_importance"), "list")
testthat::expect_setequal(names(app_driver$get_active_module_output("tbl_importance")), c("message", "call", "type"))

testthat::expect_type(app_driver$get_active_module_output("tbl_eigenvector"), "list")
testthat::expect_setequal(names(app_driver$get_active_module_output("tbl_eigenvector")), c("message", "call", "type"))
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings for 'plot type' does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()

# Plot type (select each)

# Changing input will trigger an output change
app_driver$set_active_module_input("plot_type", "Circle plot")
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("plot_type", "Biplot")
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("plot_type", "Eigenvector plot")
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("plot_type", "Elbow plot") # Initial value
app_driver$expect_no_validation_error()
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings of 'standardization' does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# Pre-processing

app_driver$set_active_module_input("standardization", "center")
app_driver$expect_no_validation_error
app_driver$set_active_module_input("standardization", "center_scale")
app_driver$expect_no_validation_error
app_driver$set_active_module_input("standardization", "none") # Initial value
app_driver$expect_no_validation_error
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings of 'NA action' does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# NA Action

app_driver$set_active_module_input("na_action", "drop")
app_driver$set_active_module_input("na_action", "none")
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings of 'plot_type' hides and shows options", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# Selected plot's specific settings is not visible
no_plot_settings_selector <- sprintf("#%s-%s %s", app_driver$active_module_ns(), "plot_settings", "span.help-block")
x_axis_selector <- sprintf("#%s-%s", app_driver$active_module_ns(), "x_axis")
color_by_selector <- sprintf(
"#%s-%s",
app_driver$active_module_ns(),
"response-dataset_USArrests_singleextract-select_input"
)

app_driver$set_active_module_input("plot_type", "Elbow plot", wait = FALSE)
testthat::expect_true(app_driver$is_visible(no_plot_settings_selector))
testthat::expect_false(app_driver$is_visible(x_axis_selector))
testthat::expect_false(app_driver$is_visible(color_by_selector))

app_driver$set_active_module_input("plot_type", "Circle plot", wait = FALSE)
testthat::expect_false(app_driver$is_visible(no_plot_settings_selector))
testthat::expect_true(app_driver$is_visible(x_axis_selector))

app_driver$set_active_module_input("plot_type", "Biplot", wait = FALSE)
testthat::expect_false(app_driver$is_visible(no_plot_settings_selector))
testthat::expect_true(app_driver$is_visible(x_axis_selector))
testthat::expect_true(app_driver$is_visible(color_by_selector))
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings of 'theme' does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# Theme

app_driver$set_active_module_input("ggtheme-selectized", "bw")
app_driver$expect_no_validation_error()
app_driver$set_active_module_input("ggtheme-selectized", "light")
app_driver$expect_no_validation_error()
app_driver$set_active_module_input("ggtheme-selectized", "dark")
app_driver$expect_no_validation_error()
})

testthat::test_that("e2e - tm_a_pca: Changing output encodings of 'font size' does not generate errors", {
skip_if_too_deep(5)

app_driver <- app_driver_tm_a_pca()
app_driver$expect_no_validation_error()

# Font size

app_driver$set_active_module_input("font_size", "8")
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("font_size", "20")
app_driver$expect_no_validation_error()

app_driver$set_active_module_input("font_size", "15")
app_driver$expect_no_validation_error()

app_driver$stop()
})
Loading