summaryrefslogtreecommitdiff
path: root/tests/foreign.scm
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))