123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475 |
- use dioxus::prelude::*;
- #[test]
- fn simple() {
- #[component]
- fn App(cx: Scope) -> Element {
- render! { div { "hello!" } }
- }
- let mut dom = VirtualDom::new(App);
- _ = dom.rebuild();
- assert_eq!(dioxus_ssr::render(&dom), "<div>hello!</div>");
- assert_eq!(
- dioxus_ssr::render_lazy(rsx!( div {"hello!"} )),
- "<div>hello!</div>"
- );
- }
- #[test]
- fn lists() {
- assert_eq!(
- dioxus_ssr::render_lazy(rsx! {
- ul {
- (0..5).map(|i| rsx! {
- li { "item {i}" }
- })
- }
- }),
- "<ul><li>item 0</li><li>item 1</li><li>item 2</li><li>item 3</li><li>item 4</li></ul>"
- );
- }
- #[test]
- fn dynamic() {
- let dynamic = 123;
- assert_eq!(
- dioxus_ssr::render_lazy(rsx! {
- div { "Hello world 1 -->" "{dynamic}" "<-- Hello world 2" }
- }),
- "<div>Hello world 1 -->123<-- Hello world 2</div>"
- );
- }
- #[test]
- fn components() {
- #[component]
- fn MyComponent(cx: Scope, name: i32) -> Element {
- render! { div { "component {name}" } }
- }
- assert_eq!(
- dioxus_ssr::render_lazy(rsx! {
- div {
- (0..5).map(|name| rsx! {
- MyComponent { name: name }
- })
- }
- }),
- "<div><div>component 0</div><div>component 1</div><div>component 2</div><div>component 3</div><div>component 4</div></div>"
- );
- }
- #[test]
- fn fragments() {
- assert_eq!(
- dioxus_ssr::render_lazy(rsx! {
- div {
- (0..5).map(|_| rsx! (()))
- }
- }),
- "<div></div>"
- );
- }
|