(deftest :oodml/select/1
(mapcar #'(lambda (e) (slot-value e 'last-name))
- (clsql:select 'employee :order-by [last-name]))
+ (clsql:select 'employee :order-by [last-name] :flatp t))
("Andropov" "Brezhnev" "Chernenko" "Gorbachev" "Kruschev" "Lenin" "Putin"
"Stalin" "Trotsky" "Yeltsin"))
(deftest :oodml/select/2
(mapcar #'(lambda (e) (slot-value e 'name))
- (clsql:select 'company))
+ (clsql:select 'company :flatp t))
("Widgets Inc."))
(deftest :oodml/select/3
(mapcar #'(lambda (e) (slot-value e 'companyid))
(clsql:select 'employee
- :where [and [= [slot-value 'employee 'companyid]
- [slot-value 'company 'companyid]]
- [= [slot-value 'company 'name]
- "Widgets Inc."]]))
+ :where [and [= [slot-value 'employee 'companyid]
+ [slot-value 'company 'companyid]]
+ [= [slot-value 'company 'name]
+ "Widgets Inc."]]
+ :flatp t))
(1 1 1 1 1 1 1 1 1 1))
(deftest :oodml/select/4
(slot-value e 'last-name)))
(clsql:select 'employee :where [= [slot-value 'employee 'first-name]
"Vladamir"]
+ :flatp t
:order-by [last-name]))
("Vladamir Lenin" "Vladamir Putin"))
-;; sqlite fails this because it is typeless
(deftest :oodml/select/5
- (length (clsql:select 'employee :where [married]))
+ (length (clsql:select 'employee :where [married] :flatp t))
3)
+(deftest :oodml/select/6
+ (let ((a (caar (clsql:select 'address :where [= 1 [addressid]]))))
+ (values
+ (slot-value a 'street-number)
+ (slot-value a 'street-name)
+ (slot-value a 'city)
+ (slot-value a 'postal-code)))
+ 10 "Park Place" "Leningrad" 123)
+
+(deftest :oodml/select/7
+ (let ((a (caar (clsql:select 'address :where [= 2 [addressid]]))))
+ (values
+ (slot-value a 'street-number)
+ (slot-value a 'street-name)
+ (slot-value a 'city)
+ (slot-value a 'postal-code)))
+ nil "" "no city" 0)
+
+(deftest :oodml/select/8
+ (mapcar #'(lambda (e) (slot-value e 'married))
+ (clsql:select 'employee :flatp t :order-by [emplid]))
+ (t t t nil nil nil nil nil nil nil))
+
+(deftest :oodml/select/9
+ (mapcar #'(lambda (pair)
+ (list
+ (typep (car pair) 'address)
+ (typep (second pair) 'employee-address)
+ (slot-value (car pair) 'addressid)
+ (slot-value (second pair) 'addressid)))
+ (employee-addresses employee1))
+ ((t t 1 1) (t t 2 2)))
+
+(deftest :oodml/select/10
+ (mapcar #'(lambda (pair)
+ (list
+ (typep (car pair) 'address)
+ (typep (second pair) 'employee-address)
+ (slot-value (car pair) 'addressid)
+ (slot-value (second pair) 'addressid)))
+ (employee-addresses employee2))
+ ((t t 2 2)))
+
+
;; tests update-records-from-instance
(deftest :oodml/update-records/1
(values
(progn
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
(clsql:update-records-from-instance employee1)
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
(clsql:update-records-from-instance employee1)
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
(values
(employee-email
(car (clsql:select 'employee
- :where [= [slot-value 'employee 'emplid] 1])))
+ :where [= [slot-value 'employee 'emplid] 1]
+ :flatp t)))
(progn
(setf (slot-value employee1 'email) "lenin-nospam@soviet.org")
(clsql:update-record-from-slot employee1 'email)
(employee-email
(car (clsql:select 'employee
- :where [= [slot-value 'employee 'emplid] 1]))))
+ :where [= [slot-value 'employee 'emplid] 1]
+ :flatp t))))
(progn
(setf (slot-value employee1 'email) "lenin@soviet.org")
(clsql:update-record-from-slot employee1 'email)
(employee-email
(car (clsql:select 'employee
- :where [= [slot-value 'employee 'emplid] 1])))))
+ :where [= [slot-value 'employee 'emplid] 1]
+ :flatp t)))))
"lenin@soviet.org" "lenin-nospam@soviet.org" "lenin@soviet.org")
;; tests update-record-from-slots
(values
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
(clsql:update-record-from-slots employee1 '(first-name last-name email))
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
(clsql:update-record-from-slots employee1 '(first-name last-name email))
(let ((lenin (car (clsql:select 'employee
:where [= [slot-value 'employee 'emplid]
- 1]))))
+ 1]
+ :flatp t))))
(concatenate 'string
(first-name lenin)
" "
"lenin@soviet.org" "lenin-nospam@soviet.org" "lenin@soviet.org")
-;(deftest :oodml/iteration/1
-; (clsql:do-query ((e) [select 'clsql-tests::employee :where [married]
-; :order-by [emplid]])
-; (slot-value e last-name))
-; ("Lenin" "Stalin" "Trotsky"))
+(deftest :oodml/do-query/1
+ (let ((result '()))
+ (clsql:do-query ((e) [select 'employee :order-by [emplid]])
+ (push (slot-value e 'last-name) result))
+ result)
+ ("Putin" "Yeltsin" "Gorbachev" "Chernenko" "Andropov" "Brezhnev" "Kruschev"
+ "Trotsky" "Stalin" "Lenin"))
+
+(deftest :oodml/do-query/2
+ (let ((result '()))
+ (clsql:do-query ((e c) [select 'employee 'company
+ :where [= [slot-value 'employee 'last-name]
+ "Lenin"]])
+ (push (list (slot-value e 'last-name) (slot-value c 'name))
+ result))
+ result)
+ (("Lenin" "Widgets Inc.")))
+
+(deftest :oodml/map-query/1
+ (clsql:map-query 'list #'last-name [select 'employee :order-by [emplid]])
+ ("Lenin" "Stalin" "Trotsky" "Kruschev" "Brezhnev" "Andropov" "Chernenko"
+ "Gorbachev" "Yeltsin" "Putin"))
-;(deftest :oodml/iteration/2
-; (clsql:map-query 'list #'last-name [select 'employee :where [married]
-; :order-by [emplid]])
-; ("Lenin" "Stalin" "Trotsky"))
+(deftest :oodml/map-query/2
+ (clsql:map-query 'list #'(lambda (e c) (list (slot-value e 'last-name)
+ (slot-value c 'name)))
+ [select 'employee 'company :where [= [slot-value 'employee 'last-name]
+ "Lenin"]])
+ (("Lenin" "Widgets Inc.")))
-;(deftest :oodml/iteration/3
-; (loop for (e) being the tuples in
-; [select 'employee :where [married] :order-by [emplid]]
-; collect (slot-value e 'last-name))
-; ("Lenin" "Stalin" "Trotsky"))
+(deftest :oodml/iteration/3
+ (loop for (e) being the records in
+ [select 'employee :where [< [emplid] 4] :order-by [emplid]]
+ collect (slot-value e 'last-name))
+ ("Lenin" "Stalin" "Trotsky"))
))