hsx/tests/element.lisp

54 lines
2 KiB
Common Lisp
Raw Normal View History

2024-05-25 12:48:35 +00:00
(defpackage :hsx-test/element
2024-05-25 03:00:39 +00:00
(:use :cl
:fiveam
2024-05-25 12:48:35 +00:00
:hsx/element))
(in-package :hsx-test/element)
2024-05-25 03:00:39 +00:00
(def-suite create-element)
(in-suite create-element)
2024-05-25 15:57:06 +00:00
(test create-builtin-element
2024-05-25 03:00:39 +00:00
(let* ((inner (create-element "span"
'(:class "red")
"World!"))
(outer (create-element "p"
nil
"Hello,"
inner)))
2024-05-25 15:57:06 +00:00
(is (string= (element-kind inner) "span"))
(is (equal (element-props inner) `(:class "red")))
(is (equal (element-children inner) (list "World!")))
(is (string= (element-kind outer) "p"))
(is (null (element-props outer)))
(is (equal (element-children outer) (list "Hello," inner)))))
2024-05-25 03:00:39 +00:00
2024-05-25 10:38:54 +00:00
(test flatten-element-children
(let* ((elm (create-element "p"
nil
"a"
nil
(list "b" (list nil "c"))
2024-05-25 15:57:06 +00:00
(cons "d" "e"))))
(is (equal (element-children elm) (list "a" "b" "c" "d" "e")))))
2024-05-25 10:38:54 +00:00
2024-05-25 03:00:39 +00:00
(test create-component-element
(labels ((comp (&key variant children)
(create-element "p"
`(:class ,variant)
"Hello,"
children)))
(let* ((inner (create-element "span"
nil
"World!"))
(outer (create-element #'comp
'(:variant "red")
inner)))
2024-05-25 15:57:06 +00:00
(is (eql (element-kind outer) #'comp))
(is (equal (element-props outer) `(:variant "red")))
(is (equal (element-children outer) (list inner)))
(let ((expanded-elm (expand outer)))
(is (string= (element-kind expanded-elm) "p"))
(is (equal (element-props expanded-elm) `(:class "red")))
(is (equal (element-children expanded-elm) (list "Hello," inner)))))))