File: scheme.kwargs.scm

package info (click to toggle)
guile-lib 0.2.6.1-2
  • links: PTS, VCS
  • area: main
  • in suites: bullseye
  • size: 1,868 kB
  • sloc: lisp: 6,986; sh: 3,962; makefile: 195
file content (51 lines) | stat: -rw-r--r-- 1,900 bytes parent folder | download | duplicates (7)
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
;; guile-lib
;; Copyright (C) 2007 Andy Wingo <wingo at pobox dot com>

;; This program is free software; you can redistribute it and/or    
;; modify it under the terms of the GNU General Public License as   
;; published by the Free Software Foundation; either version 2 of   
;; the License, or (at your option) any later version.              
;;                                                                  
;; This program 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 General Public License for more details.                     
;;                                                                  
;; You should have received a copy of the GNU General Public License
;; along with this program; if not, contact:
;;
;; Free Software Foundation           Voice:  +1-617-542-5942
;; 59 Temple Place - Suite 330        Fax:    +1-617-542-2652
;; Boston, MA  02111-1307,  USA       gnu@gnu.org

;;; Commentary:
;;
;; Unit tests for (scheme kwargs).
;;
;;; Code:

(use-modules (oop goops)
             (unit-test)
             (scheme kwargs))

(define-class <test-scheme-kwargs> (<test-case>))

(define-method (test-lambda/kwargs (self <test-scheme-kwargs>))
 (define frobulate (lambda/kwargs (foo (bar 13) (baz 42))
                     (list foo bar baz)))
 (assert-equal '(#f 13 42)
               (frobulate))
 (assert-equal '(#f 13 3)
               (frobulate #:baz 3))
 (assert-equal '(3 13 42)
               (frobulate #:foo 3))
 (assert-equal '(3 4 42)
               (frobulate 3 4))
 (assert-equal '(1 2 3)
               (frobulate 1 2 3))
 (assert-equal '(#f 1 2)
               (frobulate #:baz 2 #:bar 1))
 (assert-equal '(3 20 42)
               (frobulate 10 20 #:foo 3)))

(exit-with-summary (run-all-defined-test-cases))