mirror of
https://github.com/DioxusLabs/dioxus
synced 2025-01-04 16:58:51 +00:00
54 lines
1.9 KiB
Rust
54 lines
1.9 KiB
Rust
|
//! Kept in its own file to more easily import into the book
|
||
|
|
||
|
use console_error_panic_hook;
|
||
|
use virtual_dom_rs::prelude::*;
|
||
|
use wasm_bindgen::JsCast;
|
||
|
use web_sys::{Element, Node};
|
||
|
|
||
|
/// A test case that both diffing and patching are working in a real browser
|
||
|
pub struct DiffPatchTest<'a> {
|
||
|
/// Description of the test case.
|
||
|
pub desc: &'static str,
|
||
|
/// The old virtual node.
|
||
|
pub old: VirtualNode,
|
||
|
/// The new virtual node.
|
||
|
pub new: VirtualNode,
|
||
|
/// By default we generate the expected based on `new.to_string()`. You can
|
||
|
/// use this field to override the expected HTML after patching.
|
||
|
pub override_expected: Option<&'a str>,
|
||
|
}
|
||
|
|
||
|
impl<'a> DiffPatchTest<'a> {
|
||
|
pub fn test(&mut self) {
|
||
|
console_error_panic_hook::set_once();
|
||
|
|
||
|
let document = web_sys::window().unwrap().document().unwrap();
|
||
|
|
||
|
// Create a DOM node of the virtual root node
|
||
|
let root_node: Node = self.old.create_dom_node().node;
|
||
|
|
||
|
// Clone since virtual_dom_rs::patch takes ownership of the root node.
|
||
|
let patched_root_node: Node = root_node.clone();
|
||
|
|
||
|
// Generate patches
|
||
|
let patches = virtual_dom_rs::diff(&self.old, &self.new);
|
||
|
|
||
|
// Patch our root node. It should now look like `self.new`
|
||
|
virtual_dom_rs::patch(root_node, &patches);
|
||
|
|
||
|
// Determine the expected outer HTML
|
||
|
let expected_outer_html = match self.override_expected {
|
||
|
Some(ref expected) => expected.to_string(),
|
||
|
None => self.new.to_string(),
|
||
|
};
|
||
|
|
||
|
let actual_outer_html = match patched_root_node.node_type() {
|
||
|
Node::ELEMENT_NODE => patched_root_node.unchecked_into::<Element>().outer_html(),
|
||
|
Node::TEXT_NODE => patched_root_node.text_content().unwrap_or("".into()),
|
||
|
_ => panic!("Unhandled node type"),
|
||
|
};
|
||
|
|
||
|
assert_eq!(&actual_outer_html, &expected_outer_html, "{}", self.desc);
|
||
|
}
|
||
|
}
|