2022-11-24 07:15:01 +00:00
|
|
|
use dioxus::prelude::*;
|
2023-07-15 00:13:49 +00:00
|
|
|
|
2023-07-20 01:40:43 +00:00
|
|
|
#[test]
|
2024-01-15 17:06:27 +00:00
|
|
|
fn suspense_resolves() {
|
2022-11-24 07:15:01 +00:00
|
|
|
// wait just a moment, not enough time for the boundary to resolve
|
2022-11-06 22:28:41 +00:00
|
|
|
|
2023-07-20 01:40:43 +00:00
|
|
|
tokio::runtime::Builder::new_current_thread()
|
|
|
|
.build()
|
|
|
|
.unwrap()
|
|
|
|
.block_on(async {
|
|
|
|
let mut dom = VirtualDom::new(app);
|
2024-01-15 17:06:27 +00:00
|
|
|
dom.rebuild(&mut dioxus_core::NoOpMutations);
|
2023-07-20 01:40:43 +00:00
|
|
|
dom.wait_for_suspense().await;
|
2023-12-27 16:23:56 +00:00
|
|
|
let out = dioxus_ssr::render(&dom);
|
2023-01-09 21:50:33 +00:00
|
|
|
|
2023-07-20 01:40:43 +00:00
|
|
|
assert_eq!(out, "<div>Waiting for... child</div>");
|
2023-01-09 21:50:33 +00:00
|
|
|
|
2023-07-20 01:40:43 +00:00
|
|
|
dbg!(out);
|
|
|
|
});
|
2022-11-06 22:28:41 +00:00
|
|
|
}
|
|
|
|
|
2024-01-11 16:48:04 +00:00
|
|
|
fn app() -> Element {
|
2024-01-16 19:18:46 +00:00
|
|
|
rsx!(
|
2022-11-24 07:15:01 +00:00
|
|
|
div {
|
2023-07-15 00:12:07 +00:00
|
|
|
"Waiting for... "
|
|
|
|
suspended_child {}
|
2022-11-24 07:15:01 +00:00
|
|
|
}
|
2024-01-11 01:21:15 +00:00
|
|
|
)
|
2022-11-09 03:39:37 +00:00
|
|
|
}
|
|
|
|
|
2024-01-11 17:11:44 +00:00
|
|
|
fn suspended_child() -> Element {
|
|
|
|
let mut val = use_signal(|| 0);
|
2023-07-14 23:15:20 +00:00
|
|
|
|
2024-01-16 21:51:02 +00:00
|
|
|
if val() < 3 {
|
2024-01-11 18:40:36 +00:00
|
|
|
spawn(async move {
|
2023-07-15 00:12:07 +00:00
|
|
|
val += 1;
|
|
|
|
});
|
2024-01-11 18:40:36 +00:00
|
|
|
suspend()?;
|
2023-07-15 00:12:07 +00:00
|
|
|
}
|
2023-07-14 23:15:20 +00:00
|
|
|
|
2024-01-16 19:18:46 +00:00
|
|
|
rsx!("child")
|
2022-11-06 22:28:41 +00:00
|
|
|
}
|