db_based_model_test.cljs 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. (ns frontend.db.db-based-model-test
  2. (:require [cljs.test :refer [use-fixtures deftest is testing]]
  3. [frontend.db.model :as model]
  4. [frontend.db :as db]
  5. [frontend.test.helper :as test-helper]
  6. [datascript.core :as d]
  7. [logseq.outliner.property :as outliner-property]))
  8. (def repo test-helper/test-db-name-db-version)
  9. (def init-data (test-helper/initial-test-page-and-blocks))
  10. (defn start-and-destroy-db
  11. [f]
  12. (test-helper/db-based-start-and-destroy-db
  13. f
  14. {:init-data (fn [conn] (d/transact! conn init-data))}))
  15. (def fbid (:block/uuid (second init-data)))
  16. (def sbid (:block/uuid (nth init-data 2)))
  17. (use-fixtures :each start-and-destroy-db)
  18. (deftest get-all-classes-test
  19. (let [opts {:redirect? false :create-first-block? false :class? true}
  20. _ (test-helper/create-page! "class1" opts)
  21. _ (test-helper/create-page! "class2" opts)]
  22. (is (= ["Asset" "Card" "Cards" "Journal" "Query" "Root Tag" "Task" "class1" "class2"] (sort (map :block/title (model/get-all-classes repo)))))))
  23. (deftest ^:fix-me get-class-objects-test
  24. (let [opts {:redirect? false :create-first-block? false :class? true}
  25. _ (test-helper/create-page! "class1" opts)
  26. class (db/get-case-page "class1")
  27. _ (test-helper/save-block! repo fbid "Block 1" {:tags ["class1"]})]
  28. (is (= (map :db/id (model/get-class-objects repo (:db/id class)))
  29. [(:db/id (db/entity [:block/uuid fbid]))]))
  30. (testing "classes parent"
  31. (test-helper/create-page! "class2" opts)
  32. ;; set class2's parent to class1
  33. (let [class2 (db/get-case-page "class2")]
  34. (db/transact! [{:db/id (:db/id class2)
  35. :logseq.property/parent (:db/id class)}]))
  36. (test-helper/save-block! repo sbid "Block 2" {:tags ["class2"]})
  37. (is (= (map :db/id (model/get-class-objects repo (:db/id class)))
  38. [(:db/id (db/entity [:block/uuid fbid]))
  39. (:db/id (db/entity [:block/uuid sbid]))])))))
  40. (deftest get-classes-with-property-test
  41. (let [opts {:redirect? false :create-first-block? false :class? true}
  42. _ (test-helper/create-page! "class1" opts)
  43. _ (test-helper/create-page! "class2" opts)
  44. class1 (db/get-case-page "class1")
  45. class2 (db/get-case-page "class2")
  46. conn (db/get-db false)]
  47. (outliner-property/upsert-property! conn :user.property/property-1 {:type :node} {})
  48. (outliner-property/class-add-property! conn (:db/id class1) :user.property/property-1)
  49. (outliner-property/class-add-property! conn (:db/id class2) :user.property/property-1)
  50. (let [property (db/entity :user.property/property-1)
  51. classes (model/get-classes-with-property (:db/ident property))]
  52. (is (= (set (map :db/id classes))
  53. #{(:db/id class1) (:db/id class2)})))))
  54. (deftest hidden-page-test
  55. (let [opts {:redirect? false :create-first-block? false}
  56. _ (test-helper/create-page! "page 1" opts)]
  57. (is (false? (model/hidden-page? (db/get-page "page 1"))))
  58. (is (true? (model/hidden-page? "$$$test")))
  59. (is (true? (model/hidden-page? (str "$$$" (random-uuid)))))))
  60. (deftest get-class-children-test
  61. (let [opts {:redirect? false :create-first-block? false :class? true}
  62. _ (test-helper/create-page! "class1" opts)
  63. _ (test-helper/create-page! "class2" opts)
  64. _ (test-helper/create-page! "class3" opts)
  65. class1 (db/get-case-page "class1")
  66. class2 (db/get-case-page "class2")
  67. class3 (db/get-case-page "class3")
  68. _ (db/transact! [{:db/id (:db/id class2)
  69. :logseq.property/parent (:db/id class1)}
  70. {:db/id (:db/id class3)
  71. :logseq.property/parent (:db/id class2)}])]
  72. (is
  73. (= (model/get-structured-children repo (:db/id (db/get-case-page "class1")))
  74. [(:db/id class2) (:db/id class3)]))))