user.clj 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. (ns user
  2. "fns used on repl"
  3. (:require [clojure.test :refer [run-tests run-test]]
  4. [logseq.e2e.block :as b]
  5. [logseq.e2e.commands-basic-test]
  6. [logseq.e2e.config :as config]
  7. [logseq.e2e.fixtures :as fixtures]
  8. [logseq.e2e.graph :as graph]
  9. [logseq.e2e.keyboard :as k]
  10. [logseq.e2e.locator :as loc]
  11. [logseq.e2e.multi-tabs-basic-test]
  12. [logseq.e2e.outliner-basic-test]
  13. [logseq.e2e.plugins-basic-test]
  14. [logseq.e2e.property-basic-test]
  15. [logseq.e2e.reference-basic-test]
  16. [logseq.e2e.rtc-basic-test]
  17. [logseq.e2e.rtc-extra-test]
  18. [logseq.e2e.tag-basic-test]
  19. [logseq.e2e.util :as util]
  20. [wally.main :as w]
  21. [wally.repl :as repl]))
  22. ;; Use port 3001 for local testing
  23. (reset! config/*port 3001)
  24. ;; show ui
  25. (reset! config/*headless false)
  26. (reset! config/*slow-mo 30)
  27. (def *futures (atom {}))
  28. (defn cancel
  29. [test-name]
  30. (some-> (get @*futures test-name) future-cancel)
  31. (swap! *futures dissoc test-name))
  32. (defn run-commands-test
  33. []
  34. (->> (future (run-tests 'logseq.e2e.commands-basic-test))
  35. (swap! *futures assoc :commands-test)))
  36. (defn run-property-basic-test
  37. []
  38. (->> (future (run-tests 'logseq.e2e.property-basic-test))
  39. (swap! *futures assoc :property-test)))
  40. (defn run-outliner-test
  41. []
  42. (->> (future (run-tests 'logseq.e2e.outliner-basic-test))
  43. (swap! *futures assoc :outliner-test)))
  44. (defn run-rtc-basic-test
  45. []
  46. (->> (future (run-tests 'logseq.e2e.rtc-basic-test))
  47. (swap! *futures assoc :rtc-basic-test)))
  48. (defn run-multi-tabs-test
  49. []
  50. (->> (future (run-tests 'logseq.e2e.multi-tabs-basic-test))
  51. (swap! *futures assoc :multi-tabs-test)))
  52. (defn run-reference-test
  53. []
  54. (->> (future (run-tests 'logseq.e2e.reference-basic-test))
  55. (swap! *futures assoc :reference-test)))
  56. (defn run-plugins-test
  57. []
  58. (->> (future (run-tests 'logseq.e2e.plugins-basic-test))
  59. (swap! *futures assoc :plugins-test)))
  60. (defn run-rtc-extra-test
  61. []
  62. (->> (future (run-tests 'logseq.e2e.rtc-extra-test))
  63. (swap! *futures assoc :rtc-extra-test)))
  64. (defn run-all-basic-test
  65. []
  66. (run-tests 'logseq.e2e.commands-basic-test
  67. 'logseq.e2e.multi-tabs-basic-test
  68. 'logseq.e2e.outliner-basic-test
  69. 'logseq.e2e.rtc-basic-test
  70. 'logseq.e2e.plugins-basic-test
  71. 'logseq.e2e.reference-basic-test
  72. 'logseq.e2e.property-basic-test
  73. 'logseq.e2e.tag-basic-test))
  74. (defn start
  75. []
  76. (future
  77. (fixtures/open-page
  78. repl/pause
  79. {:headless false})))
  80. (comment
  81. ;; You can call or put `(repl/pause)` in any test to pause the tests,
  82. ;; this allows us to continue experimenting with the current page.
  83. (repl/pause)
  84. ;; To resume the tests, close the page/context/browser
  85. (repl/resume)
  86. ;; Run specific test
  87. (future (run-test logseq.e2e.commands-test/new-property-test))
  88. ;; after the test has been paused, you can do anything with the current page like this
  89. (repl/with-page
  90. (w/wait-for (first (util/get-edit-block-container))
  91. {:state :detached}))
  92. (run-tests 'logseq.e2e.commands-basic-test
  93. 'logseq.e2e.multi-tabs-basic-test
  94. 'logseq.e2e.outliner-basic-test
  95. 'logseq.e2e.rtc-basic-test)
  96. (do
  97. (reset! config/*headless true)
  98. (reset! config/*slow-mo 10)
  99. (run-tests 'logseq.e2e.reference-basic-test)
  100. (dotimes [i 10]
  101. (run-tests 'logseq.e2e.reference-basic-test)))
  102. ;;
  103. )