tvl-depot/users/wpcarro/emacs/pkgs/list/tests.el
William Carroll b880fc4a14 refactor(wpcarro/emacs): Remove list.el's dep on dash.el 🎉
Still pruning the dependency tree. Thank you, seq.el, from DWIMing.

Change-Id: I797f08abe44853b9d297a99d5ba9e9bde3dcfeec
Reviewed-on: https://cl.tvl.fyi/c/depot/+/6040
Reviewed-by: wpcarro <wpcarro@gmail.com>
Autosubmit: wpcarro <wpcarro@gmail.com>
Tested-by: BuildkiteCI
2022-08-05 18:44:00 +00:00

67 lines
2.2 KiB
EmacsLisp

;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Dependencies
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(require 'ert)
(require 'list)
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;; Tests
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(setq xs '(1 2 3 4 5))
(ert-deftest list-length ()
(should (= 0 (list-length '())))
(should (= 5 (list-length xs))))
(ert-deftest list-reduce ()
(should (= 16 (list-reduce 1 (lambda (x acc) (+ x acc)) xs))))
(ert-deftest list-map ()
(should
(equal '(2 4 6 8 10)
(list-map (lambda (x) (* x 2)) xs))))
(ert-deftest list-xs-distinct-by? ()
(should
(equal t (list-xs-distinct-by?
(lambda (x) (plist-get x :kbd))
'((:kbd "C-a" :name "foo")
(:kbd "C-b" :name "foo"))))))
(ert-deftest list-dedupe-adjacent ()
(should (equal '(1 2 3 4 3 5)
(list-dedupe-adjacent '(1 1 1 2 2 3 4 4 3 5 5)))))
(ert-deftest list-contains? ()
;; Assert returns t or nil
(should (equal t (list-contains? 1 xs)))
(should (equal nil (list-contains? 100 xs))))
(ert-deftest list-join ()
(should (equal "foo-bar-baz"
(list-join "-" '("foo" "bar" "baz")))))
(ert-deftest list-chunk ()
(should (equal '((1 2 3 4 5 6))
(list-chunk 7 '(1 2 3 4 5 6))))
(should (equal '((1) (2) (3) (4) (5) (6))
(list-chunk 1 '(1 2 3 4 5 6))))
(should (equal '((1 2 3) (4 5 6))
(list-chunk 3 '(1 2 3 4 5 6))))
(should (equal '((1 2) (3 4) (5 6))
(list-chunk 2 '(1 2 3 4 5 6)))))
(ert-deftest list-find ()
(should (equal 2 (list-find (lambda (x) (= 2 x)) '(1 2 3 4)))))
(ert-deftest list-all? ()
(should (equal t (list-all? (lambda (x) (= 2 x)) nil)))
(should (null (list-all? (lambda (x) (= 2 x)) '(1 2 3))))
(should (equal t (list-all? (lambda (x) (= 2 x)) '(2 2 2 2)))))
(ert-deftest list-any? ()
(should (null (list-any? (lambda (x) (= 2 x)) nil)))
(should (equal t (list-any? (lambda (x) (= 2 x)) '(1 2 3))))
(should (null (list-any? (lambda (x) (= 4 x)) '(1 2 3)))))