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

Add 312-bslib-sidebar-resize #166

Open
wants to merge 29 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
29 commits
Select commit Hold shift + click to select a range
dca0e3c
Add 312-bslib-sidebar-resize (manual app)
gadenbuie May 8, 2023
eac7185
Use `page_navbar()` for shared sidebar
gadenbuie May 9, 2023
daf5438
Programmatically test sidebar transition
gadenbuie May 9, 2023
db7723f
Generate apps deps (GitHub Actions)
gadenbuie May 9, 2023
ff5c45b
Update tests to use `diff()` and to include labels on all expectations
gadenbuie May 9, 2023
620c85c
Merge 'origin/main' into '312-bslib-sidebar-resize'
gadenbuie May 9, 2023
3673e29
Generate apps deps (GitHub Actions)
gadenbuie May 9, 2023
844bf7f
Refactor test code to avoid duplication
gadenbuie May 10, 2023
6164d43
Another small refactor for better failure backtraces
gadenbuie May 10, 2023
9eaee9a
Add client-size htmlwidget resizing test
gadenbuie May 15, 2023
0f8ef3c
Remove call to `browser()`
gadenbuie May 15, 2023
247df09
Merged origin/main into 312-bslib-sidebar-resize
gadenbuie May 18, 2023
50767b2
add debugging for windows and limit to just windows
gadenbuie May 18, 2023
2e443c3
debug: try again
gadenbuie May 18, 2023
b78e103
debug: more output printing
gadenbuie May 18, 2023
e7ad0ed
Revert debugging changes
gadenbuie May 19, 2023
6e42aea
Use `nav_panel()`
gadenbuie May 19, 2023
93831c8
Rename test file
gadenbuie May 19, 2023
d0f224d
Skip transition animation tests on windows
gadenbuie May 19, 2023
eb49d67
Split out helper code, split tests into blocks
gadenbuie May 19, 2023
09ecf09
Add README for 312
gadenbuie May 19, 2023
38fa35c
skip on windows without help from {shinycoreci}
gadenbuie May 19, 2023
509aca1
Merge 'origin/main' into '312-bslib-sidebar-resize'
gadenbuie May 20, 2023
610e93c
Generate apps deps (GitHub Actions)
gadenbuie May 20, 2023
c11a494
test again after routine file changes
gadenbuie May 20, 2023
52612da
bring back some debugging output
gadenbuie May 22, 2023
bee1c57
slow down transition to see if that helps
gadenbuie May 22, 2023
452178b
Hide debug messages behind envvar
gadenbuie May 22, 2023
8671d17
Add a `$wait_for_js()` to keep test in sync with browser
gadenbuie May 22, 2023
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
33 changes: 32 additions & 1 deletion inst/apps/312-bslib-sidebar-resize/app.R
Original file line number Diff line number Diff line change
Expand Up @@ -57,7 +57,7 @@ ui <- page_navbar(
),
nav(
"Widget",
h2("Widget plot resizing", class = "mt-4 mb-2"),
h2("Widget plot resizing"),
p(
"The plot in the layout below should stretch while the sidebar is opening",
"or closing. There should be no layout shift after the transition is",
Expand All @@ -83,6 +83,37 @@ ui <- page_navbar(
div(class = "col-6", lorem2, lorem1)
)
),
nav(
"Client",
h2("Client-side htmlwidget resizing"),
p(
"The plot in the layout below should stretch while the sidebar is opening",
"or closing. There should be no layout shift after the transition is",
"complete."
),
layout_sidebar(
sidebar = sidebar(
title = "Toggle me",
id = "sidebar-local-client",
lorem1, lorem2, lorem1
),
lorem1,
div(id = "plot_client_local", plot_ly(x = rnorm(100))),
lorem2
),
h2("Shared only", class = "my-3"),
p(
"The next plot should resize smoothly only when the shared sidebar is transitioning."
),
div(
class = "row",
div(
class = "col-6",
div(id = "plot_client_shared", plot_ly(x = rnorm(100)))
),
div(class = "col-6", lorem2, lorem1)
)
),
footer = div(style = "min-height: 100vh")
)

Expand Down
49 changes: 35 additions & 14 deletions inst/apps/312-bslib-sidebar-resize/tests/testthat/test-shinytest2.R
Original file line number Diff line number Diff line change
Expand Up @@ -55,19 +55,24 @@ js_element_width <- function(selector) {
watch_sidebar_transition <- function(
app,
sidebar = c("shared", "local"),
page = c("static", "widget")
page = c("static", "widget", "client")
) {
sidebar <- match.arg(sidebar)
page <- match.arg(page)

id_sidebar <- if (sidebar == "shared") "sidebar-shared" else paste0("sidebar-local-", page)
sel_plot <- function(which = c("shared", "local")) {
plot_container <-
if (page == "static") {
"img"
} else {
".plot-container > .svg-container"
}
id_sidebar <- switch(
sidebar,
shared = "sidebar-shared",
paste0("sidebar-local-", page)
)

sel_plot <- function(which = c("shared", "local" , "client")) {
plot_container <- switch(
page,
static = "img",
widget = ".plot-container > .svg-container",
client = ".plotly > .plot-container > .svg-container"
)
paste0("#plot_", page, "_", which, " > ", plot_container)
}
sel_plot_img_local <- sel_plot("local")
Expand Down Expand Up @@ -125,7 +130,7 @@ window.updatedOutputs = [];
expect_sidebar_transition <- function(
app,
sidebar = c("shared", "local"),
page = c("static", "widget"),
page = c("static", "widget", "client"),
open_end = c("open", "closed")
) {
sidebar <- match.arg(sidebar)
Expand Down Expand Up @@ -182,6 +187,8 @@ expect_sidebar_transition <- function(
expect_plot_grows <- function(plot = c("local", "shared")) {
plot <- match.arg(plot)

browser(expr = length(res$initial[[plot]]) != 1)
gadenbuie marked this conversation as resolved.
Show resolved Hide resolved

# initial size is a lower bound, plots grow as sidebar collapses
expect_gt(
min(res$during[[plot]]),
Expand Down Expand Up @@ -269,9 +276,6 @@ test_that("312-bslib-sidebar-resize", {
expect_values_screenshot_args = FALSE
)

expect_sidebar_hidden <- expect_sidebar_hidden_factory(app)
expect_sidebar_shown <- expect_sidebar_shown_factory(app)

# STATIC PAGE ================================================================

# collapse static shared sidebar --------------------------------------------
Expand All @@ -286,7 +290,7 @@ test_that("312-bslib-sidebar-resize", {
# SWITCH TO WIDGET PAGE ======================================================
app$
click(selector = '.nav-link[data-value="Widget"]')$
wait_for_js("document.getElementById('js-plotly-tester') ? true : false")
wait_for_js("$('#plot_widget_local:visible .svg-container').length > 0")

# now we repeat all of the same tests above, except that the widget resizing
# won't trigger a 'shiny:value' event.
Expand All @@ -299,4 +303,21 @@ test_that("312-bslib-sidebar-resize", {

# expand widget shared sidebar ----------------------------------------------
expect_sidebar_transition(app, "shared", "widget", open_end = "open")

# SWITCH TO CLIENT PAGE ======================================================
app$
click(selector = '.nav-link[data-value="Client"]')$
wait_for_js("$('#plot_client_local:visible .svg-container').length > 0")

# now we repeat all of the same tests above, except that the widget resizing
# won't trigger a 'shiny:value' event.

# collapse widget shared sidebar --------------------------------------------
expect_sidebar_transition(app, "shared", "client", open_end = "closed")

# collapse widget local sidebar ---------------------------------------------
expect_sidebar_transition(app, "local", "client", open_end = "closed")

# expand widget shared sidebar ----------------------------------------------
expect_sidebar_transition(app, "shared", "client", open_end = "open")
})