summary refs log tree commit diff stats
diff options
context:
space:
mode:
-rw-r--r--test-vartika-plus.lisp150
-rw-r--r--test.lisp31
2 files changed, 181 insertions, 0 deletions
diff --git a/test-vartika-plus.lisp b/test-vartika-plus.lisp
new file mode 100644
index 0000000..1f45933
--- /dev/null
+++ b/test-vartika-plus.lisp
@@ -0,0 +1,150 @@
+(load "test.lisp")
+(load "plus-inc.lisp")
+
+;;; basic functions
+
+(deftest test-explode ()
+  (check
+    (equal (explode 1) '(|1|))
+    (equal (explode 22211) '(|2| |2| |2| |1| |1|))))
+
+(deftest test-explode-string ()
+  (check
+    (equal (explode-string "1") '(|1|))
+    (equal (explode-string "22211") '(|2| |2| |2| |1| |1|))))
+
+(deftest test-implode ()
+  (check
+    (eq (implode '(|1|)) '|1|)
+    (eq (implode '(|2| |1| |3|)) '|213|)))
+
+(deftest test-symbol-to-number ()
+  (check
+    (eql (symbol-to-number '|1|) 1)
+    (eql (symbol-to-number '|231|) 231)))
+
+(deftest test-base-number ()
+  (check
+    (base-number '(|1|) '|1|)
+    (base-number '(|1| |1| |1|) '|1|)
+    (base-number nil '|1|)
+    (null (base-number '(|2|) '|1|))
+    (null (base-number '(|1| |2| |1|) '|1|))
+    (null (base-number '(|1| |2| |3|) '|1|))
+    (null (base-number '(|2| |3| |4|) '|1|))))
+
+(deftest test-may-reverse-units-first ()
+  (setf *number-units-at-beginning* t)
+  (check
+    (equal (may-reverse '(|1|)) '(|1|))
+    (equal (may-reverse '(|1| |1| |1|)) '(|1| |1| |1|))
+    (equal (may-reverse '(|1| |2| |3|)) '(|1| |2| |3|))))
+
+(deftest test-may-reverse-units-last ()
+  (setf *number-units-at-beginning* nil)
+  (check
+    (equal (may-reverse '(|1|)) '(|1|))
+    (equal (may-reverse '(|1| |1| |1|)) '(|1| |1| |1|))
+    (equal (may-reverse '(|1| |2| |3|)) '(|3| |2| |1|))))
+
+
+(deftest test-basic ()
+  (combine-results
+    (test-explode)
+    (test-explode-string)
+    (test-implode)
+    (test-symbol-to-number)
+    (test-base-number)
+    (test-may-reverse-units-first)
+    (test-may-reverse-units-last)))
+
+
+;;; one
+;;; earthal, infinite
+
+(deftest test-earth-next-digit ()
+  (let ((numerals '(|1| |2| |3| |4| |5|)))
+    (check
+      (eq (next-digit numerals '|1|) '|2|)
+      (eq (next-digit numerals '|3|) '|4|)
+      (eq (next-digit numerals '|5|) nil))))
+
+(deftest test-earth-previous-digit ()
+  (let ((numerals '(|1| |2| |3| |4| |5|)))
+    (check
+      (eq (previous-digit numerals '|1|) nil)
+      (eq (previous-digit numerals '|3|) '|2|)
+      (eq (previous-digit numerals '|5|) '|4|))))
+
+(deftest test-earth-infinite-next-list-number ()
+  (setf *number-units-at-beginning* t)
+  (let ((numerals '(|1| |2| |3| |4| |5|)))
+    (check
+      (equal (next-list-number numerals nil) '(|1|))
+      (equal (next-list-number numerals '(|1|)) '(|2|))
+      (equal (next-list-number numerals '(|1| |3|)) '(|2| |3|))
+      (equal (next-list-number numerals '(|5|)) '(|1| |2|))
+      (equal (next-list-number numerals '(|1| |1|)) '(|2| |1|))
+      (equal (next-list-number numerals '(|1| |3| |1| |1|)) '(|2| |3| |1| |1|))
+      (equal (next-list-number numerals '(|5| |5|)) '(|1| |1| |2|))
+      (equal (next-list-number numerals '(|1| |5| |5|)) '(|2| |5| |5|))
+      (equal (next-list-number numerals '(|5| |5| |5|)) '(|1| |1| |1| |2|))
+      (equal (next-list-number numerals '(|5| |5| |1|)) '(|1| |1| |2| |1|))
+      (equal (next-list-number numerals '(|5| |5| |1| |1| |1|)) '(|1| |1| |2| |1| |1| |1|))
+      (equal (next-list-number numerals '(|4| |5| |1| |1| |1|)) '(|5| |5| |1| |1| |1|))
+      (equal (next-list-number numerals '(|4| |5| |1|)) '(|5| |5| |1|))
+      (equal (next-list-number numerals '(|5| |5| |2| |1|)) '(|1| |1| |3| |1|)))))
+
+(deftest test-earth-infinite-previous-list-number ()
+  (setf *number-units-at-beginning* t)
+  (let ((numerals '(|1| |2| |3| |4| |5|)))
+    (check
+      (equal (previous-list-number numerals '(|1|)) nil)
+      (equal (previous-list-number numerals '(|1| |1|)) nil)
+      (equal (previous-list-number numerals '(|1| |1| |1|)) nil)
+      (equal (previous-list-number numerals '(|2|)) '(|1|))
+      (equal (previous-list-number numerals '(|5|)) '(|4|))
+      (equal (previous-list-number numerals '(|2| |3|)) '(|1| |3|))
+      (equal (previous-list-number numerals '(|5| |5|)) '(|4| |5|))
+      (equal (previous-list-number numerals '(|1| |5|)) '(|5| |4|))
+      (equal (previous-list-number numerals '(|1| |2|)) '(|5|))
+      (equal (previous-list-number numerals '(|2| |3| |1|)) '(|1| |3| |1|))
+      (equal (previous-list-number numerals '(|2| |3| |1| |1|)) '(|1| |3| |1| |1|))
+      (equal (previous-list-number numerals '(|1| |1| |2| |3|)) '(|5| |5| |1| |3|))
+      (equal (previous-list-number numerals '(|5| |5| |1| |1| |1|)) '(|4| |5| |1| |1| |1|))
+      (equal (previous-list-number numerals '(|1| |5| |1|)) '(|5| |4| |1|))
+      (equal (previous-list-number numerals '(|1| |5| |1| |1|)) '(|5| |4| |1| |1|))
+      (equal (previous-list-number numerals '(|1| |2| |1|)) '(|5| |1|))
+      (equal (previous-list-number numerals '(|1| |2| |1| |1|)) '(|5| |1| |1|))
+      (equal (previous-list-number numerals '(|2| |2| |1| |1|)) '(|1| |2| |1| |1|)))))
+
+(deftest test-earth-plus-args-list ()
+  (setf *number-units-at-beginning* t)
+  (let ((numerals '(|1| |2| |3| |4| |5|)))
+    (check
+      (equal (plus-args-list numerals '(|1|) '(|1|)) '(|1|))
+      (equal (plus-args-list numerals '(|2|) '(|1|)) '(|2|))
+      (equal (plus-args-list numerals '(|1|) '(|2|)) '(|2|))
+      (equal (plus-args-list numerals '(|2|) '(|2|)) '(|3|))
+      (equal (plus-args-list numerals '(|5|) '(|2|)) '(|1| |2|))
+      (equal (plus-args-list numerals '(|2|) '(|5|)) '(|1| |2|))
+      (equal (plus-args-list numerals '(|1| |3|) '(|1|)) '(|1| |3|))
+      (equal (plus-args-list numerals '(|2| |3|) '(|2|)) '(|3| |3|))
+      (equal (plus-args-list numerals '(|2| |3|) '(|5|)) '(|1| |4|))
+      (equal (plus-args-list numerals '(|2| |2|) '(|2| |2|)) '(|3| |3|))
+      (equal (plus-args-list numerals '(|3| |2|) '(|5| |3|)) '(|2| |5|))
+      (equal (plus-args-list numerals '(|3| |3|) '(|5| |3|)) '(|2| |1| |2|)))))
+
+(deftest test-earth-inf ()
+  (combine-results
+    (test-earth-next-digit)
+    (test-earth-previous-digit)
+    (test-earth-infinite-next-list-number)
+    (test-earth-infinite-previous-list-number)
+    (test-earth-plus-args-list)))
+
+
+
+(deftest test-earth ()
+  (test-basic)
+  (test-earth-inf))
diff --git a/test.lisp b/test.lisp
new file mode 100644
index 0000000..5f65ccc
--- /dev/null
+++ b/test.lisp
@@ -0,0 +1,31 @@
+;(in-package :test)
+
+(defvar *test-name* nil)
+
+(defmacro with-gensyms ((&rest names) &body body)
+  `(let ,(loop for n in names collect `(,n (gensym)))
+     ,@body))
+
+(defmacro deftest (name parameters &body body)
+  "Define a test function. Within a test function we can call other
+test functions or use `check' to run individual test cases."
+  `(defun ,name ,parameters
+     (let ((*test-name* (append *test-name* (list ',name))))
+       ,@body)))
+
+(defmacro check (&body forms)
+  "Run each expression in `forms' as a test case."
+  `(combine-results
+    ,@(loop for f in forms collect `(report-result ,f ',f))))
+
+(defmacro combine-results (&body forms)
+  "Combine the results (as booleans) of evaluating `forms' in order."
+  (with-gensyms (result)
+    `(let ((,result t))
+      ,@(loop for f in forms collect `(unless ,f (setf ,result nil)))
+      ,result)))
+
+(defun report-result (result form)
+  "Report the results of a single test case. Called by `check'."
+  (format t "~:[FAIL~;pass~] ... ~a: ~a~%" result *test-name* form)
+  result)