123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- //! dynamic attributes in dioxus necessitate an allocated node ID.
- //!
- //! This tests to ensure we clean it up
- use bumpalo::Bump;
- use dioxus::core::{ElementId, Mutation::*};
- use dioxus::prelude::*;
- use dioxus_core::BorrowedAttributeValue;
- #[test]
- fn attrs_cycle() {
- let mut dom = VirtualDom::new(|cx| {
- let id = cx.generation();
- match cx.generation() % 2 {
- 0 => cx.render(rsx! {
- div {}
- }),
- 1 => cx.render(rsx! {
- div {
- h1 { class: "{id}", id: "{id}" }
- }
- }),
- _ => unreachable!(),
- }
- });
- let bump = Bump::new();
- assert_eq!(
- dom.rebuild().santize().edits,
- [
- LoadTemplate { name: "template", index: 0, id: ElementId(1,) },
- AppendChildren { m: 1, id: ElementId(0) },
- ]
- );
- dom.mark_dirty(ScopeId(0));
- assert_eq!(
- dom.render_immediate().santize().edits,
- [
- LoadTemplate { name: "template", index: 0, id: ElementId(2,) },
- AssignId { path: &[0,], id: ElementId(3,) },
- SetAttribute {
- name: "class",
- value: (&*bump.alloc("1".into_value(&bump))).into(),
- id: ElementId(3,),
- ns: None
- },
- SetAttribute {
- name: "id",
- value: (&*bump.alloc("1".into_value(&bump))).into(),
- id: ElementId(3,),
- ns: None
- },
- ReplaceWith { id: ElementId(1,), m: 1 },
- ]
- );
- dom.mark_dirty(ScopeId(0));
- assert_eq!(
- dom.render_immediate().santize().edits,
- [
- LoadTemplate { name: "template", index: 0, id: ElementId(1) },
- ReplaceWith { id: ElementId(2), m: 1 }
- ]
- );
- dom.mark_dirty(ScopeId(0));
- assert_eq!(
- dom.render_immediate().santize().edits,
- [
- LoadTemplate { name: "template", index: 0, id: ElementId(2) },
- AssignId { path: &[0], id: ElementId(3) },
- SetAttribute {
- name: "class",
- value: BorrowedAttributeValue::Text("3"),
- id: ElementId(3),
- ns: None
- },
- SetAttribute {
- name: "id",
- value: BorrowedAttributeValue::Text("3"),
- id: ElementId(3),
- ns: None
- },
- ReplaceWith { id: ElementId(1), m: 1 }
- ]
- );
- // we take the node taken by attributes since we reused it
- dom.mark_dirty(ScopeId(0));
- assert_eq!(
- dom.render_immediate().santize().edits,
- [
- LoadTemplate { name: "template", index: 0, id: ElementId(1) },
- ReplaceWith { id: ElementId(2), m: 1 }
- ]
- );
- }
|