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
|
;-*- Mode: Lisp -*-
;;;; Author: Paul Dietz
;;;; Created: Sat Sep 6 19:56:29 2003
;;;; Contains: Tests of COMPLEX
(in-package :cl-test)
;;; Error tests
(deftest complex.error.1
(signals-error (complex) program-error)
t)
(deftest complex.error.2
(signals-error (complex 1 1 nil) program-error)
t)
;;; Non-error tests
(deftest complex.1
(loop for x in *rationals*
for c = (complex x)
always (eql c x))
t)
(deftest complex.2
(loop for x in *floats*
for c = (complex x)
always (and (complexp c)
(eql x (realpart c))
(eql (float 0 x) (imagpart c))))
t)
(deftest complex.3
(loop for x in *rationals*
for c = (complex 0 x)
unless (or (zerop x)
(and (complexp c)
(eql (realpart c) 0)
(eql (imagpart c) x)))
collect (list c x))
nil)
(deftest complex.4
(loop for x in *floats*
for c = (complex 0 x)
always (and (complexp c)
(eql (float 0 x) (realpart c))
(eql x (imagpart c))))
t)
;;; Tests of some properties of complex numbers
(deftest complex.5
(loop for c in *complexes*
unless (loop for type in '(short-float single-float double-float long-float)
always (if (typep (realpart c) type)
(typep (imagpart c) type)
(not (typep (imagpart c) type))))
collect c)
nil)
|