2013-08-17 14:29:30 +00:00
|
|
|
(ns grub.db-spec
|
|
|
|
(:require [speclj.core :refer :all]
|
|
|
|
[grub.db :as db]
|
|
|
|
[monger.collection :as mc]
|
|
|
|
[clojure.core.async :refer [>!! <!! timeout]]))
|
|
|
|
|
|
|
|
(def test-db "grub-test")
|
|
|
|
|
|
|
|
(defn short-delay []
|
2013-08-31 07:29:49 +00:00
|
|
|
(<!! (timeout 50)))
|
2013-08-18 11:13:55 +00:00
|
|
|
|
|
|
|
(defn get-test-grub []
|
|
|
|
{:_id (str "grub" (rand-int 10000))
|
|
|
|
:grub (str "testtext" (rand-int 1000))
|
|
|
|
:completed ([true false] (rand-int 1))})
|
2013-08-17 14:29:30 +00:00
|
|
|
|
|
|
|
(describe
|
|
|
|
"grub.db"
|
2013-08-18 11:13:55 +00:00
|
|
|
(before-all (db/connect-and-handle-events test-db))
|
2013-08-18 11:36:16 +00:00
|
|
|
(before (db/clear-grubs))
|
|
|
|
(describe "Add"
|
|
|
|
(it "should add a grub when an add event comes"
|
2013-08-17 14:29:30 +00:00
|
|
|
(let [test-grub "testgrub"
|
|
|
|
test-id 12345]
|
2013-08-18 11:36:16 +00:00
|
|
|
(>!! @db/incoming-events {:event :add
|
|
|
|
:_id test-id
|
|
|
|
:grub test-grub
|
|
|
|
:completed false})
|
2013-08-17 14:29:30 +00:00
|
|
|
(short-delay)
|
|
|
|
(should=
|
|
|
|
{:_id test-id :grub test-grub :completed false}
|
|
|
|
(mc/find-one-as-map db/grub-collection {:_id test-id})))))
|
|
|
|
|
2013-08-18 11:36:16 +00:00
|
|
|
(describe "Complete"
|
2013-08-17 14:29:30 +00:00
|
|
|
(it "should complete a grub when a complete event comes"
|
|
|
|
(let [test-grub {:_id 123456 :completed false}]
|
|
|
|
(mc/insert db/grub-collection test-grub)
|
|
|
|
(>!! @db/incoming-events {:event :complete :_id (:_id test-grub)})
|
|
|
|
(short-delay)
|
|
|
|
(should=
|
|
|
|
{:_id (:_id test-grub) :completed true}
|
|
|
|
(mc/find-one-as-map db/grub-collection {:_id (:_id test-grub)})))))
|
|
|
|
|
2013-08-18 11:36:16 +00:00
|
|
|
(describe "Uncomplete"
|
2013-08-17 14:29:30 +00:00
|
|
|
(it "should uncomplete a grub when an uncomplete event comes"
|
|
|
|
(let [test-grub {:_id 123456 :completed true}]
|
|
|
|
(mc/insert db/grub-collection test-grub)
|
|
|
|
(>!! @db/incoming-events {:event :uncomplete :_id (:_id test-grub)})
|
|
|
|
(short-delay)
|
|
|
|
(should=
|
|
|
|
{:_id (:_id test-grub) :completed false}
|
|
|
|
(mc/find-one-as-map db/grub-collection {:_id (:_id test-grub)})))))
|
|
|
|
|
2013-09-01 10:39:35 +00:00
|
|
|
(describe "Update"
|
|
|
|
(it "should update grub info when an update event comes"
|
|
|
|
(let [test-grub {:_id 123456 :grub "original"}]
|
|
|
|
(mc/insert db/grub-collection test-grub)
|
|
|
|
(>!! @db/incoming-events {:event :update
|
|
|
|
:_id (:_id test-grub)
|
|
|
|
:grub "updated"})
|
|
|
|
(short-delay)
|
|
|
|
(should=
|
|
|
|
{:_id (:_id test-grub) :grub "updated"}
|
|
|
|
(mc/find-one-as-map db/grub-collection {:_id (:_id test-grub)})))))
|
|
|
|
|
2013-08-18 11:36:16 +00:00
|
|
|
(describe "Delete"
|
2013-08-17 14:29:30 +00:00
|
|
|
(it "should delete a grub when a delete event comes"
|
|
|
|
(let [test-grub {:_id 123456 :completed true}]
|
|
|
|
(mc/insert db/grub-collection test-grub)
|
|
|
|
(>!! @db/incoming-events {:event :delete :_id (:_id test-grub)})
|
|
|
|
(short-delay)
|
|
|
|
(should=
|
|
|
|
nil
|
2013-08-25 10:53:47 +00:00
|
|
|
(mc/find-one-as-map db/grub-collection {:_id (:_id test-grub)})))))
|
|
|
|
|
|
|
|
(describe "Clear all"
|
|
|
|
(it "should delete all grubs"
|
|
|
|
(let [test-grub {:_id 123456 :completed true}]
|
|
|
|
(mc/insert db/grub-collection test-grub)
|
|
|
|
(>!! @db/incoming-events {:event :clear-all})
|
|
|
|
(short-delay)
|
|
|
|
(should
|
|
|
|
(empty?
|
|
|
|
(mc/find-maps db/grub-collection)))))))
|