File: test-pool.lisp

package info (click to toggle)
cl-sql 6.7.2-1.1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm, sid
  • size: 3,552 kB
  • sloc: lisp: 24,508; xml: 17,898; makefile: 487; ansic: 201; sh: 39; cpp: 9
file content (83 lines) | stat: -rw-r--r-- 3,491 bytes parent folder | download | duplicates (3)
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
;;;; -*- Mode: LISP; Syntax: ANSI-Common-Lisp; Base: 10 -*-
;;;; *************************************************************************
;;;; FILE IDENTIFICATION
;;;;
;;;; Name:    test-pool.lisp
;;;; Purpose: Tests for connection pools
;;;; Author:  Ryan Davis
;;;; Created: June 27 2011
;;;;
;;;; This file, part of CLSQL, is Copyright (c) 2004-2010 by Kevin M. Rosenberg
;;;;
;;;; CLSQL users are granted the rights to distribute and use this software
;;;; as governed by the terms of the Lisp Lesser GNU Public License
;;;; (http://opensource.franz.com/preamble.html), also known as the LLGPL.
;;;; *************************************************************************
(in-package #:clsql-tests)

;; setup a dummy database for the pool to use
(pushnew :dummy clsql-sys:*loaded-database-types*)
(defclass dummy-database (clsql-sys:database) ()
  (:default-initargs :database-type :dummy))
(defmethod clsql-sys:database-connect (connection-spec (database-type (eql :dummy)))
  (let ((db (make-instance 'dummy-database :connection-spec connection-spec)))
    (setf (slot-value db 'clsql-sys::state) :open)
    db))
(defmethod clsql-sys::database-name-from-spec (connection-spec (database-type (eql :dummy)))
  "dummy")
(defmethod clsql-sys::database-acquire-from-conn-pool ((db dummy-database)) T)

(setq *rt-pool*
  '(
    (deftest :pool/acquire
     (let ((pool (clsql-sys::find-or-create-connection-pool nil :dummy))
           dbx res)
       (clsql-sys::clear-conn-pool pool)
       (flet ((test-result (x) (push x res)))
         (test-result (length (clsql-sys::all-connections pool)))
         (test-result (length (clsql-sys::free-connections pool)))

         (clsql-sys:with-database (db nil :database-type :dummy :pool T)
           (test-result (not (null db)))
           (test-result (length (clsql-sys::all-connections pool)))
           (test-result (length (clsql-sys::free-connections pool)))
           (setf dbx db))
         (test-result (length (clsql-sys::all-connections pool)))
         (test-result (length (clsql-sys::free-connections pool)))
         (clsql-sys:with-database (db nil :database-type :dummy :pool T)
           (test-result (eq db dbx)))
         )
       (nreverse res))
     (0 0 T 1 0 1 1 T)
     )

    (deftest :pool/max-free-connections
     (let ((pool (clsql-sys::find-or-create-connection-pool nil :dummy)))
       (flet ((run (max-free dbs-to-release)
                (let ((clsql-sys:*db-pool-max-free-connections* max-free)
                      dbs)
                  (clsql-sys::clear-conn-pool pool)
                  (dotimes (i dbs-to-release dbs)
                    (push (clsql-sys:connect nil :database-type :dummy
                                                 :pool T :if-exists :new)
                          dbs))
                  (list (length (clsql-sys::all-connections pool))
                        (progn
                          (dolist (db dbs) (clsql-sys:disconnect :database db))
                          (length (clsql-sys::free-connections pool))
                          )))))
         (append
          (run 5 10)
          (run nil 10))))
     (10 5 10 10)
     )



    (deftest :pool/find-or-create-connection-pool
     (let ((p (clsql-sys::find-or-create-connection-pool nil :dummy)))
       (values (null p)
               (eq p (clsql-sys::find-or-create-connection-pool nil :dummy))
               (eq p (clsql-sys::find-or-create-connection-pool :spec :dummy))))
     nil T nil)
    ))