blob: d3470bc6d0b89d276c9c68676d0de322c84338de (
about) (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
|
;; Fibers: cooperative, event-driven user-space threads.
;;;; Copyright (C) 2016 Free Software Foundation, Inc.
;;;;
;;;; This library is free software; you can redistribute it and/or
;;;; modify it under the terms of the GNU Lesser General Public
;;;; License as published by the Free Software Foundation; either
;;;; version 3 of the License, or (at your option) any later version.
;;;;
;;;; This library is distributed in the hope that it will be useful,
;;;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
;;;; Lesser General Public License for more details.
;;;;
;;;; You should have received a copy of the GNU Lesser General Public
;;;; License along with this library; if not, write to the Free Software
;;;; Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
;;;;
(define-module (tests foreign)
#:use-module (fibers)
#:use-module (fibers operations)
#:use-module (fibers channels)
#:use-module (fibers timers)
#:use-module (ice-9 threads))
(define failed? #f)
(define-syntax-rule (assert-equal expected actual)
(let ((x expected))
(format #t "assert ~s equal to ~s: " 'actual x)
(force-output)
(let ((y actual))
(cond
((equal? x y) (format #t "ok\n"))
(else
(format #t "no (got ~s)\n" y)
(set! failed? #t))))))
(define-syntax-rule (assert-terminates exp)
(begin
(format #t "assert ~s terminates: " 'exp)
(force-output)
exp
(format #t "ok\n")))
(define (receive-from-fiber x)
(let* ((ch (make-channel))
(t (call-with-new-thread
(lambda ()
(run-fibers (lambda () (put-message ch 42))))))
(v (get-message ch)))
(join-thread t)
v))
(define (send-to-fiber x)
(let* ((ch (make-channel))
(t (call-with-new-thread
(lambda ()
(run-fibers (lambda () (get-message ch)))))))
(put-message ch x)
(join-thread t)))
(assert-equal #f #f)
(assert-terminates #t)
(assert-terminates (sleep 1))
(assert-terminates (perform-operation (wait-operation 1)))
(assert-equal 42 (receive-from-fiber 42))
(assert-equal 42 (send-to-fiber 42))
(exit (if failed? 1 0))
|