hsx/tests/element.lisp

79 lines
2.7 KiB
Common Lisp
Raw Normal View History

2024-05-27 07:54:46 +00:00
(defpackage #:hsx-test/element
(:use #:cl
#:fiveam
#:hsx/element))
(in-package #:hsx-test/element)
2024-05-25 03:00:39 +00:00
2024-05-26 03:26:09 +00:00
(def-suite element-test)
(in-suite element-test)
2024-05-28 11:48:39 +00:00
(test tag
(let ((elm (create-element :p
2024-05-27 07:03:23 +00:00
'(:class "red")
"Hello,"
"World")))
2024-05-29 02:47:48 +00:00
(is (eq :p (element-type elm)))
(is (equal '(:class "red") (element-props elm)))
(is (equal (list "Hello," "World") (element-children elm)))))
2024-05-26 03:26:09 +00:00
(test flatten-children
(let* ((elm (create-element :p
2024-05-25 10:38:54 +00:00
nil
"a"
nil
(list "b" (list nil "c"))
2024-05-25 15:57:06 +00:00
(cons "d" "e"))))
2024-05-29 02:47:48 +00:00
(is (equal (list "a" "b" "c" "d" "e") (element-children elm)))))
2024-05-25 10:38:54 +00:00
2024-05-26 03:26:09 +00:00
(defun comp1 (&key title children)
(create-element :div
2024-05-26 03:26:09 +00:00
nil
title
children))
2024-05-28 11:48:39 +00:00
(test component-accepting-keyword-args
2024-05-26 03:26:09 +00:00
(let* ((elm (create-element #'comp1
'(:title "foo")
"bar"))
2024-05-27 07:03:23 +00:00
(expanded (expand-component elm)))
2024-05-29 02:47:48 +00:00
(is (eq #'comp1 (element-type elm)))
(is (equal '(:title "foo") (element-props elm)))
(is (equal (list "bar") (element-children elm)))
(is (eq :div (element-type expanded)))
(is (equal (list "foo" "bar") (element-children expanded)))))
2024-05-26 03:26:09 +00:00
(defun comp2 (&rest props)
(create-element :div
2024-05-26 03:26:09 +00:00
nil
(getf props :title)
(getf props :children)))
2024-05-28 11:48:39 +00:00
(test component-accepting-property-list
2024-05-27 07:03:23 +00:00
(let* ((elm (create-element #'comp2
2024-05-26 03:26:09 +00:00
'(:title "foo")
"bar"))
2024-05-27 07:03:23 +00:00
(expanded (expand-component elm)))
2024-05-29 02:47:48 +00:00
(is (eq #'comp2 (element-type elm)))
(is (equal '(:title "foo") (element-props elm)))
(is (equal (list "bar") (element-children elm)))
(is (eq :div (element-type expanded)))
(is (equal (list "foo" "bar") (element-children expanded)))))
2024-05-26 03:26:09 +00:00
(defun comp3 (&rest props &key title children &allow-other-keys)
(create-element :div
2024-05-26 03:26:09 +00:00
nil
title
children
(getf props :other-key)))
2024-05-28 11:48:39 +00:00
(test component-accepting-keyword-args-and-property-list
2024-05-26 03:26:09 +00:00
(let* ((elm (create-element #'comp3
'(:title "foo" :other-key "baz")
"bar"))
2024-05-27 07:03:23 +00:00
(expanded (expand-component elm)))
2024-05-29 02:47:48 +00:00
(is (eq #'comp3 (element-type elm)))
(is (equal '(:title "foo" :other-key "baz") (element-props elm)))
(is (equal (list "bar") (element-children elm)))
(is (eq :div (element-type expanded)))
(is (equal (list "foo" "bar" "baz") (element-children expanded)))))