r11214: 2006-10-10 Kevin Rosenberg (kevin@rosenberg.net)
[uffi.git] / uffi-tests.asd
1 ;;;; -*- Mode: Lisp; Syntax: ANSI-Common-Lisp; Base: 10 -*-
2 ;;;; *************************************************************************
3 ;;;; FILE IDENTIFICATION
4 ;;;;
5 ;;;; Name:          uffi-tests.asd
6 ;;;; Purpose:       ASDF system definitionf for uffi testing package
7 ;;;; Author:        Kevin M. Rosenberg
8 ;;;; Date Started:  Apr 2003
9 ;;;;
10 ;;;; $Id$
11 ;;;; *************************************************************************
12
13 (defpackage #:uffi-tests-system
14   (:use #:asdf #:cl))
15 (in-package #:uffi-tests-system)
16
17 (operate 'load-op 'uffi)
18
19 (defvar *library-file-dir* (append (pathname-directory *load-truename*)
20                                    (list "tests")))
21
22 (defclass uffi-test-source-file (c-source-file)
23   ())
24
25 (defmethod output-files ((o compile-op) (c uffi-test-source-file))
26   (let* ((library-file-type
27           (funcall (intern (symbol-name'#:default-foreign-library-type)
28                            (symbol-name '#:uffi))))
29          (found
30           (some #'(lambda (dir)
31                     (probe-file (make-pathname
32                                  :directory dir
33                                  :name (component-name c)
34                                  :type library-file-type)))
35                 '((:absolute "usr" "lib" "uffi")))))
36     (list (if found
37               found
38               (make-pathname :name (component-name c)
39                              :type library-file-type
40                              :directory *library-file-dir*)))))
41
42 (defmethod perform ((o load-op) (c uffi-test-source-file))
43   nil) ;;; library will be loaded by a loader file
44
45 (defmethod operation-done-p ((o load-op) (c uffi-test-source-file))
46   (and (symbol-function (intern (symbol-name '#:cs-count-upper)
47                                 (find-package '#:uffi-tests)))
48        t))
49
50 (defmethod perform ((o compile-op) (c uffi-test-source-file))
51   (unless (operation-done-p o c)
52     #-(or win32 mswindows)
53     (unless (zerop (run-shell-command
54                     #-freebsd "cd ~A; make"
55                     #+freebsd "cd ~A; gmake"
56                     (namestring (make-pathname :name nil
57                                                :type nil
58                                                :directory *library-file-dir*))))
59       (error 'operation-error :component c :operation o))))
60
61 (defmethod operation-done-p ((o compile-op) (c uffi-test-source-file))
62   (or (and (probe-file #p"/usr/lib/uffi/uffi-c-test.so") t)
63       (let ((lib (make-pathname :defaults (component-pathname c)
64                                 :type (uffi:default-foreign-library-type))))
65         (and (probe-file lib)
66              (> (file-write-date lib) (file-write-date (component-pathname c)))))))
67
68 (defsystem uffi-tests
69     :depends-on (:uffi)
70     :components
71     ((:module tests
72               :components
73               ((:file "rt")
74                (:file "package" :depends-on ("rt"))
75                (:uffi-test-source-file "uffi-c-test" :depends-on ("package"))
76                (:file "strtol" :depends-on ("package"))
77                (:file "atoifl" :depends-on ("package"))
78                (:file "getenv" :depends-on ("package"))
79                (:file "gethostname" :depends-on ("package"))
80                (:file "union" :depends-on ("package"))
81                (:file "arrays" :depends-on ("package"))
82                (:file "structs" :depends-on ("package"))
83                (:file "objects" :depends-on ("package"))
84                (:file "time" :depends-on ("package"))
85                (:file "foreign-loader" :depends-on ("package" "uffi-c-test"))
86                (:file "uffi-c-test-lib" :depends-on ("foreign-loader"))
87                (:file "compress" :depends-on ("foreign-loader"))
88                (:file "casts" :depends-on ("foreign-loader"))
89                (:file "foreign-var" :depends-on ("foreign-loader"))
90                ))))
91
92 (defmethod perform ((o test-op) (c (eql (find-system :uffi-tests))))
93   (or (funcall (intern (symbol-name '#:do-tests)
94                        (find-package '#:regression-test)))
95       (error "test-op failed")))