Wed Jun 10 14:09:14 CEST 2009  Tobias Rautenkranz <tobias@rautenkranz.ch>
  * Test gc cycle and non cxx:object parent
hunk ./src/gc.lisp 61
-;        (cxx:set-parent (make-instance 'my-gc-object) object)
hunk ./src/gc.lisp 71
+    (eval '(gc :full t))
hunk ./src/gc.lisp 74
-    (5am:is (= count (hash-table-count smoke::*object-map*)))))
+    (5am:is (>= count (hash-table-count smoke::*object-map*)))))
hunk ./src/gc.lisp 76
-(5am:test (gc-lisp-child :depends-on (and gc-child with-app))
+;(5am:test (gc-lisp-child :depends-on (and gc-child with-app))
+(5am:test gc-lisp-child
hunk ./src/gc.lisp 83
+      ;; a.k.a :really-full ;)
hunk ./src/gc.lisp 86
+      (eval '(gc :full t))
+      (qt:core-application.send-posted-events)
+      (eval '(gc :full t))
+      (qt:core-application.send-posted-events)
hunk ./src/gc.lisp 92
-      [_$_]
hunk ./src/gc.lisp 94
+
+(defun test-gc-cycle ()
+  (qt:with-core-app
+      (dotimes (i 10)
+        (let ((timer (make-instance 'qt:timer)))
+          (qt:connect (qt:get-signal timer "timeout()")
+                      #'(lambda ()
+                          (format *debug-io* "Timeout ~A" timer)))))
+    (gc :full t)
+    (qt:core-application.send-posted-events)
+    (gc :full t)
+    (qt:core-application.send-posted-events)))
+
+(5am:test (gc-cycle :depends-on gc-lisp-child)
+  "Test GC a unreacable cycle."
+  ;; timer -> qslot -> closure(lambda)
+  ;;   ^------------------/
+  (qt:with-core-app
+  (let ((objects (hash-table-count smoke::*object-map*)))
+    (eval '(test-gc-cycle))
+    (eval '(gc :full t))
+    (qt:core-application.send-posted-events)
+    (eval '(gc :full t))
+    (qt:core-application.send-posted-events)
+    (gc :full t)
+    (qt:core-application.send-posted-events)
+    (gc :full t)
+    (5am:is (>= objects (hash-table-count smoke::*object-map*))))))
+
+(5am:test ownership-transfer-no-wrapper
+  "Test ownership tranasfer of a QObject without a wrapper."
+  (let ((grand-parent (make-instance 'qt:object)))
+    (let* ((parent (make-instance 'qt:object :args (list grand-parent)))
+           (object (make-instance 'my-object :args (list parent))))
+      (declare (ignore object)))
+    (gc :full t)
+    (qt:core-application.send-posted-events)
+    (gc :full t)
+    (qt:core-application.send-posted-events)
+    (5am:is (member (find-class 'my-object)
+                    (loop for c across (cxx:children grand-parent) append
+                         (map 'list #'class-of
+                                 (cxx:children c)))))))
+      [_$_]
hunk ./src/signal-slot.lisp 116
+;; SBCL runs the finalizer when the object has been garbage collected,
+;; thus its children could be to and thus the destroyed() signal is not
+;; received
+#-(or sbcl cmucl)