summaryrefslogtreecommitdiff
path: root/test-suite
diff options
context:
space:
mode:
authorDirk Herrmann <dirk@dirk-herrmanns-seiten.de>2001-10-26 19:47:57 +0000
committerDirk Herrmann <dirk@dirk-herrmanns-seiten.de>2001-10-26 19:47:57 +0000
commit2b6b59081af307d5bf6d89e35dc904886ccf9873 (patch)
treeb2e3aa2bce761d1a0d8717a25e5c80830385814d /test-suite
parent2ad3278ab958938f95f32ea46eb91f8ad7dca2af (diff)
downloadguile-2b6b59081af307d5bf6d89e35dc904886ccf9873.tar.gz
* tests/eval.test: Added tests for promises.
Diffstat (limited to 'test-suite')
-rw-r--r--test-suite/ChangeLog4
-rw-r--r--test-suite/tests/eval.test68
2 files changed, 72 insertions, 0 deletions
diff --git a/test-suite/ChangeLog b/test-suite/ChangeLog
index 7ee1d514f..5fae02107 100644
--- a/test-suite/ChangeLog
+++ b/test-suite/ChangeLog
@@ -1,3 +1,7 @@
+2001-10-26 Dirk Herrmann <D.Herrmann@tu-bs.de>
+
+ * tests/eval.test: Added tests for promises.
+
2001-10-21 Mikael Djurfeldt <mdj@linnaeus>
* lib.scm: Move module the system directives `export',
diff --git a/test-suite/tests/eval.test b/test-suite/tests/eval.test
index 8e94885c3..fc97fa5a9 100644
--- a/test-suite/tests/eval.test
+++ b/test-suite/tests/eval.test
@@ -177,4 +177,72 @@
(map + '(1 2) '(3)))
)))
+;;;
+;;; promises
+;;;
+
+(with-test-prefix "promises"
+
+ (with-test-prefix "basic promise behaviour"
+
+ (pass-if "delay gives a promise"
+ (promise? (delay 1)))
+
+ (pass-if "force evaluates a promise"
+ (eqv? (force (delay (+ 1 2))) 3))
+
+ (pass-if "a forced promise is a promise"
+ (let ((p (delay (+ 1 2))))
+ (force p)
+ (promise? p)))
+
+ (pass-if "forcing a forced promise works"
+ (let ((p (delay (+ 1 2))))
+ (force p)
+ (eqv? (force p) 3)))
+
+ (pass-if "a promise is evaluated once"
+ (let* ((x 1)
+ (p (delay (+ x 1))))
+ (force p)
+ (set! x (+ x 1))
+ (eqv? (force p) 2)))
+
+ (pass-if "a promise may call itself"
+ (define p
+ (let ((x 0))
+ (delay
+ (begin
+ (set! x (+ x 1))
+ (if (> x 1) x (force p))))))
+ (eqv? (force p) 2))
+
+ (pass-if "a promise carries its environment"
+ (let* ((x 1) (p #f))
+ (let* ((x 2))
+ (set! p (delay (+ x 1))))
+ (eqv? (force p) 3)))
+
+ (pass-if "a forced promise does not reference its environment"
+ (let* ((g (make-guardian))
+ (p #f))
+ (let* ((x (cons #f #f)))
+ (g x)
+ (set! p (delay (car x))))
+ (force p)
+ (gc)
+ (if (not (equal? (g) (cons #f #f)))
+ (throw 'unresolved)
+ #t))))
+
+ (with-test-prefix "extended promise behaviour"
+
+ (pass-if-exception "forcing a non-promise object is not supported"
+ exception:wrong-type-arg
+ (force 1))
+
+ (pass-if-exception "implicit forcing is not supported"
+ exception:wrong-type-arg
+ (+ (delay (* 3 7)) 13))))
+
;;; eval.test ends here