2019-06-05 08:26:05 +00:00
|
|
|
;; This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
;; License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
;; file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
;;
|
2021-04-10 09:43:04 +02:00
|
|
|
;; Copyright (c) UXBOX Labs SL
|
2019-06-05 08:26:05 +00:00
|
|
|
|
|
|
|
(ns user
|
2019-11-18 11:52:57 +01:00
|
|
|
(:require
|
2021-12-21 15:25:21 +01:00
|
|
|
[datoteka.core]
|
2021-02-15 13:14:05 +01:00
|
|
|
[app.common.exceptions :as ex]
|
2020-12-24 14:32:19 +01:00
|
|
|
[app.config :as cfg]
|
|
|
|
[app.main :as main]
|
2021-03-08 13:14:52 +01:00
|
|
|
[app.util.blob :as blob]
|
|
|
|
[app.util.json :as json]
|
2021-12-21 15:25:21 +01:00
|
|
|
[app.util.fressian :as fres]
|
2020-12-24 14:32:19 +01:00
|
|
|
[app.util.time :as dt]
|
2021-12-21 15:25:21 +01:00
|
|
|
[app.common.transit :as t]
|
2020-12-24 14:32:19 +01:00
|
|
|
[clojure.java.io :as io]
|
2021-03-08 13:14:52 +01:00
|
|
|
[clojure.pprint :refer [pprint print-table]]
|
2021-12-21 15:25:21 +01:00
|
|
|
[clojure.contrib.humanize :as hum]
|
2020-12-24 14:32:19 +01:00
|
|
|
[clojure.repl :refer :all]
|
2019-11-26 13:34:37 +01:00
|
|
|
[clojure.spec.alpha :as s]
|
2020-12-27 22:47:31 +01:00
|
|
|
[clojure.spec.gen.alpha :as sgen]
|
2020-12-24 14:32:19 +01:00
|
|
|
[clojure.test :as test]
|
2021-02-15 13:14:05 +01:00
|
|
|
[clojure.test :as test]
|
2019-11-18 11:52:57 +01:00
|
|
|
[clojure.tools.namespace.repl :as repl]
|
|
|
|
[clojure.walk :refer [macroexpand-all]]
|
2021-12-21 15:25:21 +01:00
|
|
|
[clj-async-profiler.core :as prof]
|
2019-11-18 11:52:57 +01:00
|
|
|
[criterium.core :refer [quick-bench bench with-progress-reporting]]
|
2021-03-08 13:14:52 +01:00
|
|
|
[integrant.core :as ig]))
|
2020-12-24 14:32:19 +01:00
|
|
|
|
|
|
|
(repl/disable-reload! (find-ns 'integrant.core))
|
2021-12-21 15:25:21 +01:00
|
|
|
(set! *warn-on-reflection* true)
|
2020-12-24 14:32:19 +01:00
|
|
|
|
|
|
|
(defonce system nil)
|
2019-06-05 08:26:05 +00:00
|
|
|
|
2020-01-13 15:14:29 +01:00
|
|
|
;; --- Benchmarking Tools
|
|
|
|
|
2019-11-18 11:52:57 +01:00
|
|
|
(defmacro run-quick-bench
|
|
|
|
[& exprs]
|
|
|
|
`(with-progress-reporting (quick-bench (do ~@exprs) :verbose)))
|
|
|
|
|
|
|
|
(defmacro run-quick-bench'
|
|
|
|
[& exprs]
|
|
|
|
`(quick-bench (do ~@exprs)))
|
|
|
|
|
|
|
|
(defmacro run-bench
|
|
|
|
[& exprs]
|
|
|
|
`(with-progress-reporting (bench (do ~@exprs) :verbose)))
|
|
|
|
|
|
|
|
(defmacro run-bench'
|
|
|
|
[& exprs]
|
|
|
|
`(bench (do ~@exprs)))
|
|
|
|
|
2019-06-05 08:26:05 +00:00
|
|
|
;; --- Development Stuff
|
|
|
|
|
2020-01-13 15:14:29 +01:00
|
|
|
(defn- run-tests
|
2021-05-28 13:50:42 +02:00
|
|
|
([] (run-tests #"^app.*-test$"))
|
2019-06-05 08:26:05 +00:00
|
|
|
([o]
|
2020-02-03 22:29:59 +01:00
|
|
|
(repl/refresh)
|
2019-06-05 08:26:05 +00:00
|
|
|
(cond
|
|
|
|
(instance? java.util.regex.Pattern o)
|
|
|
|
(test/run-all-tests o)
|
|
|
|
|
|
|
|
(symbol? o)
|
|
|
|
(if-let [sns (namespace o)]
|
|
|
|
(do (require (symbol sns))
|
|
|
|
(test/test-vars [(resolve o)]))
|
|
|
|
(test/test-ns o)))))
|
2020-02-24 15:29:12 +01:00
|
|
|
|
2020-12-24 14:32:19 +01:00
|
|
|
(defn- start
|
|
|
|
[]
|
|
|
|
(alter-var-root #'system (fn [sys]
|
|
|
|
(when sys (ig/halt! sys))
|
2021-03-30 14:55:19 +02:00
|
|
|
(-> main/system-config
|
2020-12-24 14:32:19 +01:00
|
|
|
(ig/prep)
|
|
|
|
(ig/init))))
|
|
|
|
:started)
|
|
|
|
|
|
|
|
(defn- stop
|
|
|
|
[]
|
|
|
|
(alter-var-root #'system (fn [sys]
|
|
|
|
(when sys (ig/halt! sys))
|
|
|
|
nil))
|
|
|
|
:stoped)
|
|
|
|
|
|
|
|
(defn restart
|
|
|
|
[]
|
|
|
|
(stop)
|
|
|
|
(repl/refresh :after 'user/start))
|
|
|
|
|
|
|
|
(defn restart-all
|
|
|
|
[]
|
|
|
|
(stop)
|
|
|
|
(repl/refresh-all :after 'user/start))
|
2021-03-08 13:14:52 +01:00
|
|
|
|
|
|
|
(defn compression-bench
|
|
|
|
[data]
|
2021-12-21 15:25:21 +01:00
|
|
|
(let [humanize (fn [v] (hum/filesize v :binary true :format " %.4f "))]
|
|
|
|
(print-table
|
|
|
|
[{:v1 (humanize (alength (blob/encode data {:version 1})))
|
|
|
|
:v2 (humanize (alength (blob/encode data {:version 2})))
|
|
|
|
:v3 (humanize (alength (blob/encode data {:version 3})))
|
|
|
|
:v4 (humanize (alength (blob/encode data {:version 4})))
|
|
|
|
}])))
|
|
|
|
|
|
|
|
|
|
|
|
;; ;; (def contents (read-string (slurp (io/resource "bool-contents-1.edn"))))
|
|
|
|
;; (def pre-data (datoteka.core/slurp-bytes (io/resource "file-data-sample")))
|
|
|
|
;; (def data (blob/decode pre-data))
|