1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495 |
- #![allow(unused, non_upper_case_globals)]
- //! Rebuilding tests
- //! ----------------
- //!
- //! This tests module ensures that the initial build of the virtualdom is correct.
- //! This does not include dynamic tests or the diffing algorithm itself.
- //!
- //! It does prove that mounting works properly and the correct edit streams are generated.
- //!
- //! Don't have a good way to validate, everything is done manually ATM
- use dioxus::prelude::*;
- use dioxus_core::DomEdit::*;
- #[test]
- fn app_runs() {
- static App: Component = |cx| rsx!(cx, div{"hello"} );
- let mut vdom = VirtualDom::new(App);
- let edits = vdom.rebuild();
- }
- #[test]
- fn fragments_work() {
- static App: Component = |cx| {
- cx.render(rsx!(
- div{"hello"}
- div{"goodbye"}
- ))
- };
- let mut vdom = VirtualDom::new(App);
- let edits = vdom.rebuild();
- // should result in a final "appendchildren n=2"
- dbg!(edits);
- }
- #[test]
- fn lists_work() {
- static App: Component = |cx| {
- cx.render(rsx!(
- h1 {"hello"}
- (0..6).map(|f| rsx!(span{ "{f}" }))
- ))
- };
- let mut vdom = VirtualDom::new(App);
- let edits = vdom.rebuild();
- dbg!(edits);
- }
- #[test]
- fn conditional_rendering() {
- static App: Component = |cx| {
- cx.render(rsx!(
- h1 {"hello"}
- {true.then(|| rsx!(span{ "a" }))}
- {false.then(|| rsx!(span{ "b" }))}
- ))
- };
- let mut vdom = VirtualDom::new(App);
- let mutations = vdom.rebuild();
- assert_eq!(
- mutations.edits,
- [
- CreateElement { root: 1, tag: "h1" },
- CreateTextNode { root: 2, text: "hello" },
- AppendChildren { many: 1 },
- CreateElement { root: 3, tag: "span" },
- CreateTextNode { root: 4, text: "a" },
- AppendChildren { many: 1 },
- CreatePlaceholder { root: 5 },
- AppendChildren { many: 3 },
- ]
- )
- }
- #[test]
- fn child_components() {
- static App: Component = |cx| {
- cx.render(rsx!(
- {true.then(|| rsx!(Child { }))}
- {false.then(|| rsx!(Child { }))}
- ))
- };
- static Child: Component = |cx| {
- cx.render(rsx!(
- h1 {"hello"}
- h1 {"goodbye"}
- ))
- };
- let mut vdom = VirtualDom::new(App);
- let edits = vdom.rebuild();
- dbg!(edits);
- }
|