diff_graphs.cljs 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. (ns diff-graphs
  2. "A script that diffs two DB graphs through their sqlite.build EDN"
  3. (:require [babashka.cli :as cli]
  4. [clojure.data :as data]
  5. [clojure.pprint :as pprint]
  6. [logseq.common.config :as common-config]
  7. [logseq.db.common.sqlite-cli :as sqlite-cli]
  8. [logseq.db.sqlite.export :as sqlite-export]
  9. [nbb.core :as nbb]))
  10. (def spec
  11. "Options spec"
  12. {:help {:alias :h
  13. :desc "Print help"}
  14. :exclude-namespaces {:alias :e
  15. :coerce #{}
  16. :desc "Namespaces to exclude from properties and classes"}
  17. :exclude-built-in-pages? {:alias :b
  18. :desc "Exclude built-in pages"}
  19. :set-diff {:alias :s
  20. :desc "Use set to reduce noisy diff caused by ordering"}
  21. :include-timestamps? {:alias :T
  22. :desc "Include timestamps in export"}
  23. :export-type {:alias :t
  24. :coerce :keyword
  25. :desc "Export type"
  26. :default :graph}})
  27. (defn -main [args]
  28. (let [{options :opts args' :args} (cli/parse-args args {:spec spec})
  29. [graph-dir graph-dir2] args'
  30. _ (when (or (nil? graph-dir) (nil? graph-dir2) (:help options))
  31. (println (str "Usage: $0 GRAPH-NAME GRAPH-NAME2 [& ARGS] [OPTIONS]\nOptions:\n"
  32. (cli/format-opts {:spec spec})))
  33. (js/process.exit 1))
  34. conn (apply sqlite-cli/open-db! (sqlite-cli/->open-db-args graph-dir))
  35. conn2 (apply sqlite-cli/open-db! (sqlite-cli/->open-db-args graph-dir2))
  36. export-args (cond-> {:export-type (:export-type options)}
  37. (= :graph (:export-type options))
  38. (assoc :graph-options (select-keys options [:include-timestamps? :exclude-namespaces :exclude-built-in-pages?])))
  39. export-map (sqlite-export/build-export @conn export-args)
  40. export-map2 (sqlite-export/build-export @conn2 export-args)
  41. prepare-export-to-diff
  42. (fn [m]
  43. (cond->
  44. (-> m
  45. ;; TODO: Fix order of these build keys
  46. (update :classes update-vals (fn [m] (update m :build/class-properties sort)))
  47. (update :properties update-vals (fn [m] (update m :build/property-classes sort)))
  48. (update ::sqlite-export/kv-values
  49. (fn [kvs]
  50. ;; Ignore extra metadata that a copied graph can add
  51. (vec (remove #(#{:logseq.kv/import-type :logseq.kv/imported-at} (:db/ident %)) kvs))))
  52. ;; TODO: fix built-in views for schema export
  53. (update :pages-and-blocks (fn [pbs]
  54. (vec (remove #(= (:block/title (:page %)) common-config/views-page-name) pbs)))))
  55. (:set-diff options)
  56. (update-vals set)))
  57. diff (->> (data/diff (prepare-export-to-diff export-map) (prepare-export-to-diff export-map2))
  58. butlast)]
  59. (if (= diff [nil nil])
  60. (println "The two graphs are equal!")
  61. (do (pprint/pprint diff)
  62. (js/process.exit 1)))))
  63. (when (= nbb/*file* (nbb/invoked-file))
  64. (-main *command-line-args*))