-
Notifications
You must be signed in to change notification settings - Fork 7
/
Copy pathtest.lisp
120 lines (107 loc) · 4.23 KB
/
test.lisp
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
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
;;; -*- show-trailing-whitespace: t; indent-tabs-mode: nil -*-
;;; Copyright (c) 2007 Ivan Shvedunov. All rights reserved.
;;; Copyright (c) 2007 David Lichteblau. All rights reserved.
;;; Redistribution and use in source and binary forms, with or without
;;; modification, are permitted provided that the following conditions
;;; are met:
;;;
;;; * Redistributions of source code must retain the above copyright
;;; notice, this list of conditions and the following disclaimer.
;;;
;;; * Redistributions in binary form must reproduce the above
;;; copyright notice, this list of conditions and the following
;;; disclaimer in the documentation and/or other materials
;;; provided with the distribution.
;;;
;;; THIS SOFTWARE IS PROVIDED BY THE AUTHOR 'AS IS' AND ANY EXPRESSED
;;; OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
;;; WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
;;; ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY
;;; DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
;;; DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
;;; GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
;;; INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
;;; WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
;;; NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
;;; SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
(cl:defpackage #:xpath-test
(:use #:common-lisp #:xpath #:xpattern #:xpath-utils)
(:import-from #:xpath
#:make-pipe
#:mappend-pipe
#:pipe-head
#:pipe-tail
#:pipe-of
#:force
#:get-node-text
#:xnum-p #:nan-p
#:+NAN+
#:with-float-traps-masked
#:compare-values
#:compare-numbers
#:make-node-set
#:parse-xnum
#:xnum-/
#:xnum-*
#:xnum-+
#:xnum--
#:xnum-mod
#:xnum-round
#:xnum-floor
#:xnum-ceiling
#:xnum->string
#:make-fixup-lexer
#:make-test-environment
#:xpath-lexer)
(:export #:run-all-tests
#:*dom-builder*
#:*document-element*))
(in-package #:xpath-test)
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
;;;
;;; Please note:
;;;
;;; When changing Plexippus XPath, also run the entire
;;; XSLT suite using Xuriella XSLT like this:
;;;
;;; $ cd xuriella && git submodule update --init
;;; > (xuriella::run-tests)
;;;
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(defvar *tests* nil)
(defmacro assert-equal (expected actual)
"Check whether two values are equal"
(with-gensyms (exp-value act-value)
`(let ((,exp-value ,expected)
(,act-value ,actual))
(unless (equal ,exp-value ,act-value)
(error "TEST FAILED: ~s is expected to be~%~s~%but was~%~s"
',actual ,exp-value ,act-value)))))
(defmacro assert-equal* (&rest pairs)
(maybe-progn
(loop for (expected actual) on pairs by #'cddr
collect `(assert-equal ,expected ,actual))))
(defmacro assert* (&rest expressions)
(maybe-progn
(loop for expr in expressions collect `(assert ,expr))))
(defmacro assert-float-equal (expected actual)
"Check whether two floating-point values are equal"
(with-gensyms (exp-value act-value)
`(let ((,exp-value ,expected)
(,act-value ,actual))
(unless (or (= ,exp-value ,act-value)
(and (nan-p ,exp-value) (nan-p ,act-value)))
(error "TEST FAILED: ~s is expected to be~%~s~%but was~%~s"
',actual ,exp-value ,act-value)))))
(defmacro assert-float-equal* (&rest pairs)
(maybe-progn
(loop for (expected actual) on pairs by #'cddr
collect `(assert-float-equal ,expected ,actual))))
(defmacro deftest (name &body body)
`(progn
(defun ,name ()
(with-float-traps-masked ()
,@body))
(pushnew ',name *tests*)))
(defun run-all-tests ()
(mapc #'funcall (sort (copy-list *tests*) #'string<)))