create.rs 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. #![allow(unused, non_upper_case_globals, non_snake_case)]
  2. use dioxus::prelude::*;
  3. use dioxus_core::ElementId;
  4. use dioxus_signals::*;
  5. #[test]
  6. fn create_signals_global() {
  7. let mut dom = VirtualDom::new(|cx| {
  8. render! {
  9. for _ in 0..10 {
  10. Child {}
  11. }
  12. }
  13. });
  14. fn Child(cx: Scope) -> Element {
  15. let signal = create_without_cx();
  16. render! {
  17. "{signal}"
  18. }
  19. }
  20. let _edits = dom.rebuild().santize();
  21. fn create_without_cx() -> Signal<String> {
  22. Signal::new("hello world".to_string())
  23. }
  24. }
  25. #[test]
  26. fn deref_signal() {
  27. let mut dom = VirtualDom::new(|cx| {
  28. render! {
  29. for _ in 0..10 {
  30. Child {}
  31. }
  32. }
  33. });
  34. fn Child(cx: Scope) -> Element {
  35. let signal = Signal::new("hello world".to_string());
  36. // You can call signals like functions to get a Ref of their value.
  37. assert_eq!(&*signal(), "hello world");
  38. render! {
  39. "hello world"
  40. }
  41. }
  42. let _edits = dom.rebuild().santize();
  43. }
  44. #[test]
  45. fn drop_signals() {
  46. let mut dom = VirtualDom::new(|cx| {
  47. let generation = generation();
  48. let count = if generation % 2 == 0 { 10 } else { 0 };
  49. render! {
  50. for _ in 0..count {
  51. Child {}
  52. }
  53. }
  54. });
  55. fn Child(cx: Scope) -> Element {
  56. let signal = create_without_cx();
  57. render! {
  58. "{signal}"
  59. }
  60. }
  61. let _ = dom.rebuild().santize();
  62. dom.mark_dirty(ScopeId::ROOT);
  63. dom.render_immediate();
  64. fn create_without_cx() -> Signal<String> {
  65. Signal::new("hello world".to_string())
  66. }
  67. }