Test also pedestal & ring-routes

This commit is contained in:
Tommi Reiman 2017-08-20 09:52:44 +03:00
parent 40fcf5761e
commit 2d5e92d116

View file

@ -2,10 +2,19 @@
(:require [clojure.test :refer [deftest testing is]] (:require [clojure.test :refer [deftest testing is]]
[cheshire.core :as json] [cheshire.core :as json]
[clojure.string :as str] [clojure.string :as str]
[reitit.core :as reitit]
[reitit.ring :as ring]
[bidi.bidi :as bidi] [bidi.bidi :as bidi]
[ataraxy.core :as ataraxy] [ataraxy.core :as ataraxy]
[compojure.api.sweet :refer [api routes context ANY]] [compojure.api.sweet :refer [api routes context ANY]]
[reitit.core :as reitit]))
[io.pedestal.http.route.definition.table :as table]
[io.pedestal.http.route.map-tree :as map-tree]
[io.pedestal.http.route.router :as pedestal]
[io.pedestal.http.route :as route]))
(defn raw-title [color s] (defn raw-title [color s]
(println (str color (apply str (repeat (count s) "#")) "\u001B[0m")) (println (str color (apply str (repeat (count s) "#")) "\u001B[0m"))
@ -89,64 +98,66 @@
;; Perf tests ;; Perf tests
;; ;;
(def handler (constantly {:status 200, :body ""}))
(def opensensors-routes (def opensensors-routes
[["/v2/whoami" :test/route1] [["/v2/whoami" {:handler handler, :name :test/route1}]
["/v2/users/:user-id/datasets" :test/route2] ["/v2/users/:user-id/datasets" {:handler handler, :name :test/route2}]
["/v2/public/projects/:project-id/datasets" :test/route3] ["/v2/public/projects/:project-id/datasets" {:handler handler, :name :test/route3}]
["/v1/public/topics/:topic" :test/route4] ["/v1/public/topics/:topic" {:handler handler, :name :test/route4}]
["/v1/users/:user-id/orgs/:org-id" :test/route5] ["/v1/users/:user-id/orgs/:org-id" {:handler handler, :name :test/route5}]
["/v1/search/topics/:term" :test/route6] ["/v1/search/topics/:term" {:handler handler, :name :test/route6}]
["/v1/users/:user-id/invitations" :test/route7] ["/v1/users/:user-id/invitations" {:handler handler, :name :test/route7}]
["/v1/orgs/:org-id/devices/:batch/:type" :test/route8] #_["/v1/orgs/:org-id/devices/:batch/:type" {:handler handler, :name :test/route8}]
["/v1/users/:user-id/topics" :test/route9] ["/v1/users/:user-id/topics" {:handler handler, :name :test/route9}]
["/v1/users/:user-id/bookmarks/followers" :test/route10] ["/v1/users/:user-id/bookmarks/followers" {:handler handler, :name :test/route10}]
["/v2/datasets/:dataset-id" :test/route11] ["/v2/datasets/:dataset-id" {:handler handler, :name :test/route11}]
["/v1/orgs/:org-id/usage-stats" :test/route12] ["/v1/orgs/:org-id/usage-stats" {:handler handler, :name :test/route12}]
["/v1/orgs/:org-id/devices/:client-id" :test/route13] ["/v1/orgs/:org-id/devices/:client-id" {:handler handler, :name :test/route13}]
["/v1/messages/user/:user-id" :test/route14] ["/v1/messages/user/:user-id" {:handler handler, :name :test/route14}]
["/v1/users/:user-id/devices" :test/route15] ["/v1/users/:user-id/devices" {:handler handler, :name :test/route15}]
["/v1/public/users/:user-id" :test/route16] ["/v1/public/users/:user-id" {:handler handler, :name :test/route16}]
["/v1/orgs/:org-id/errors" :test/route17] ["/v1/orgs/:org-id/errors" {:handler handler, :name :test/route17}]
["/v1/public/orgs/:org-id" :test/route18] ["/v1/public/orgs/:org-id" {:handler handler, :name :test/route18}]
["/v1/orgs/:org-id/invitations" :test/route19] ["/v1/orgs/:org-id/invitations" {:handler handler, :name :test/route19}]
["/v2/public/messages/dataset/bulk" :test/route20] ["/v2/public/messages/dataset/bulk" {:handler handler, :name :test/route20}]
["/v1/users/:user-id/devices/bulk" :test/route21] #_["/v1/users/:user-id/devices/bulk" {:handler handler, :name :test/route21}]
["/v1/users/:user-id/device-errors" :test/route22] ["/v1/users/:user-id/device-errors" {:handler handler, :name :test/route22}]
["/v2/login" :test/route23] ["/v2/login" {:handler handler, :name :test/route23}]
["/v1/users/:user-id/usage-stats" :test/route24] ["/v1/users/:user-id/usage-stats" {:handler handler, :name :test/route24}]
["/v2/users/:user-id/devices" :test/route25] ["/v2/users/:user-id/devices" {:handler handler, :name :test/route25}]
["/v1/users/:user-id/claim-device/:client-id" :test/route26] ["/v1/users/:user-id/claim-device/:client-id" {:handler handler, :name :test/route26}]
["/v2/public/projects/:project-id" :test/route27] ["/v2/public/projects/:project-id" {:handler handler, :name :test/route27}]
["/v2/public/datasets/:dataset-id" :test/route28] ["/v2/public/datasets/:dataset-id" {:handler handler, :name :test/route28}]
["/v2/users/:user-id/topics/bulk" :test/route29] ["/v2/users/:user-id/topics/bulk" {:handler handler, :name :test/route29}]
["/v1/messages/device/:client-id" :test/route30] ["/v1/messages/device/:client-id" {:handler handler, :name :test/route30}]
["/v1/users/:user-id/owned-orgs" :test/route31] ["/v1/users/:user-id/owned-orgs" {:handler handler, :name :test/route31}]
["/v1/topics/:topic" :test/route32] ["/v1/topics/:topic" {:handler handler, :name :test/route32}]
["/v1/users/:user-id/bookmark/:topic" :test/route33] ["/v1/users/:user-id/bookmark/:topic" {:handler handler, :name :test/route33}]
["/v1/orgs/:org-id/members/:user-id" :test/route34] ["/v1/orgs/:org-id/members/:user-id" {:handler handler, :name :test/route34}]
["/v1/users/:user-id/devices/:client-id" :test/route35] ["/v1/users/:user-id/devices/:client-id" {:handler handler, :name :test/route35}]
["/v1/users/:user-id" :test/route36] ["/v1/users/:user-id" {:handler handler, :name :test/route36}]
["/v1/orgs/:org-id/devices" :test/route37] ["/v1/orgs/:org-id/devices" {:handler handler, :name :test/route37}]
["/v1/orgs/:org-id/members" :test/route38] ["/v1/orgs/:org-id/members" {:handler handler, :name :test/route38}]
["/v1/orgs/:org-id/members/invitation-data/:user-id" :test/route39] #_["/v1/orgs/:org-id/members/invitation-data/:user-id" {:handler handler, :name :test/route39}]
["/v2/orgs/:org-id/topics" :test/route40] ["/v2/orgs/:org-id/topics" {:handler handler, :name :test/route40}]
["/v1/whoami" :test/route41] ["/v1/whoami" {:handler handler, :name :test/route41}]
["/v1/orgs/:org-id" :test/route42] ["/v1/orgs/:org-id" {:handler handler, :name :test/route42}]
["/v1/users/:user-id/api-key" :test/route43] ["/v1/users/:user-id/api-key" {:handler handler, :name :test/route43}]
["/v2/schemas" :test/route44] ["/v2/schemas" {:handler handler, :name :test/route44}]
["/v2/users/:user-id/topics" :test/route45] ["/v2/users/:user-id/topics" {:handler handler, :name :test/route45}]
["/v1/orgs/:org-id/confirm-membership/:token" :test/route46] ["/v1/orgs/:org-id/confirm-membership/:token" {:handler handler, :name :test/route46}]
["/v2/topics/:topic" :test/route47] ["/v2/topics/:topic" {:handler handler, :name :test/route47}]
["/v1/messages/topic/:topic" :test/route48] ["/v1/messages/topic/:topic" {:handler handler, :name :test/route48}]
["/v1/users/:user-id/devices/:client-id/reset-password" :test/route49] ["/v1/users/:user-id/devices/:client-id/reset-password" {:handler handler, :name :test/route49}]
["/v2/topics" :test/route50] ["/v2/topics" {:handler handler, :name :test/route50}]
["/v1/login" :test/route51] ["/v1/login" {:handler handler, :name :test/route51}]
["/v1/users/:user-id/orgs" :test/route52] ["/v1/users/:user-id/orgs" {:handler handler, :name :test/route52}]
["/v2/public/messages/dataset/:dataset-id" :test/route53] ["/v2/public/messages/dataset/:dataset-id" {:handler handler, :name :test/route53}]
["/v1/topics" :test/route54] ["/v1/topics" {:handler handler, :name :test/route54}]
["/v1/orgs" :test/route55] ["/v1/orgs" {:handler handler, :name :test/route55}]
["/v1/users/:user-id/bookmarks" :test/route56] ["/v1/users/:user-id/bookmarks" {:handler handler, :name :test/route56}]
["/v1/orgs/:org-id/topics" :test/route57]]) ["/v1/orgs/:org-id/topics" {:handler handler, :name :test/route57}]])
(def opensensors-bidi-routes (def opensensors-bidi-routes
["/" {"v1/" {"public/" {["topics/" :topic] :test/route4 ["/" {"v1/" {"public/" {["topics/" :topic] :test/route4
@ -157,7 +168,7 @@
"/topics" :route9 "/topics" :route9
"/bookmarks/followers" :test/route10 "/bookmarks/followers" :test/route10
"/devices" {"" :route15 "/devices" {"" :route15
"/bulk" :test/route21 #_#_"/bulk" :test/route21
["/" :client-id] :test/route35 ["/" :client-id] :test/route35
["/" :client-id "/reset-password"] :test/route49} ["/" :client-id "/reset-password"] :test/route49}
"/device-errors" :test/route22 "/device-errors" :test/route22
@ -173,12 +184,12 @@
"orgs" {"" :test/route55 "orgs" {"" :test/route55
["/" :org-id] {"/devices" {"" :test/route37 ["/" :org-id] {"/devices" {"" :test/route37
["/" :device-id] :test/route13 ["/" :device-id] :test/route13
["/" :batch "/" :type] :test/route8} #_#_["/" :batch "/" :type] :test/route8}
"/usage-stats" :test/route12 "/usage-stats" :test/route12
"/invitations" :test/route19 "/invitations" :test/route19
"/members" {["/" :user-id] :test/route34 "/members" {["/" :user-id] :test/route34
"" :test/route38 "" :test/route38
["/invitation-data/" :user-id] :test/route39} #_#_["/invitation-data/" :user-id] :test/route39}
"/errors" :test/route17 "/errors" :test/route17
"" :test/route42 "" :test/route42
["/confirm-membership/" :token] :test/route46 ["/confirm-membership/" :token] :test/route46
@ -217,7 +228,7 @@
"/topics" [:route9 user-id] "/topics" [:route9 user-id]
"/bookmarks/followers" [:test/route10 user-id] "/bookmarks/followers" [:test/route10 user-id]
"/devices" {"" [:route15 user-id] "/devices" {"" [:route15 user-id]
"/bulk" [:test/route21 user-id] #_#_"/bulk" [:test/route21 user-id]
["/" client-id] [:test/route35 user-id client-id] ["/" client-id] [:test/route35 user-id client-id]
["/" client-id "/reset-password"] [:test/route49 user-id client-id]} ["/" client-id "/reset-password"] [:test/route49 user-id client-id]}
"/device-errors" [:test/route22 user-id] "/device-errors" [:test/route22 user-id]
@ -233,12 +244,12 @@
"orgs" {"" [:test/route55] "orgs" {"" [:test/route55]
["/" org-id] {"/devices" {"" [:test/route37 org-id] ["/" org-id] {"/devices" {"" [:test/route37 org-id]
["/" device-id] [:test/route13 org-id device-id] ["/" device-id] [:test/route13 org-id device-id]
["/" batch "/" type] [:test/route8 org-id batch type]} #_#_["/" batch "/" type] [:test/route8 org-id batch type]}
"/usage-stats" [:test/route12 org-id] "/usage-stats" [:test/route12 org-id]
"/invitations" [:test/route19 org-id] "/invitations" [:test/route19 org-id]
"/members" {["/" user-id] [:test/route34 org-id user-id] "/members" {["/" user-id] [:test/route34 org-id user-id]
"" [:test/route38 org-id] "" [:test/route38 org-id]
["/invitation-data/" user-id] [:test/route39 org-id user-id]} #_#_["/invitation-data/" user-id] [:test/route39 org-id user-id]}
"/errors" [:test/route17 org-id] "/errors" [:test/route17 org-id]
"" [:test/route42 org-id] "" [:test/route42 org-id]
["/confirm-membership/" token] [:test/route46 org-id token] ["/confirm-membership/" token] [:test/route46 org-id token]
@ -268,7 +279,6 @@
"topics" [:test/route50]}})) "topics" [:test/route50]}}))
(def opensensors-compojure-api-routes (def opensensors-compojure-api-routes
(let [handler (constantly {:status 200, :body ""})]
(routes (routes
(context "/v1" [] (context "/v1" []
(context "/public" [] (context "/public" []
@ -282,7 +292,7 @@
(ANY "/bookmarks/followers" [] {:name :test/route10} handler) (ANY "/bookmarks/followers" [] {:name :test/route10} handler)
(context "/devices" [] (context "/devices" []
(ANY "/" [] {:name :test/route15} handler) (ANY "/" [] {:name :test/route15} handler)
(ANY "/bulk" [] {:name :test/route21} handler) #_(ANY "/bulk" [] {:name :test/route21} handler)
(ANY "/:client-id" [] {:name :test/route35} handler) (ANY "/:client-id" [] {:name :test/route35} handler)
(ANY "/:client-id/reset-password" [] {:name :test/route49} handler)) (ANY "/:client-id/reset-password" [] {:name :test/route49} handler))
(ANY "/device-errors" [] {:name :test/route22} handler) (ANY "/device-errors" [] {:name :test/route22} handler)
@ -301,13 +311,13 @@
(context "/devices" [] (context "/devices" []
(ANY "/" [] {:name :test/route37} handler) (ANY "/" [] {:name :test/route37} handler)
(ANY "/:device-id" [] {:name :test/route13} handler) (ANY "/:device-id" [] {:name :test/route13} handler)
(ANY "/:batch/:type" [] {:name :test/route8} handler)) #_(ANY "/:batch/:type" [] {:name :test/route8} handler))
(ANY "/usage-stats" [] {:name :test/route12} handler) (ANY "/usage-stats" [] {:name :test/route12} handler)
(ANY "/invitations" [] {:name :test/route19} handler) (ANY "/invitations" [] {:name :test/route19} handler)
(context "/members" [] (context "/members" []
(ANY "/:user-id" [] {:name :test/route34} handler) (ANY "/:user-id" [] {:name :test/route34} handler)
(ANY "/" [] {:name :test/route38} handler) (ANY "/" [] {:name :test/route38} handler)
(ANY "/invitation-data/:user-id" [] {:name :test/route39} handler)) #_(ANY "/invitation-data/:user-id" [] {:name :test/route39} handler))
(ANY "/errors" [] {:name :test/route17} handler) (ANY "/errors" [] {:name :test/route17} handler)
(ANY "/" [] {:name :test/route42} handler) (ANY "/" [] {:name :test/route42} handler)
(ANY "/confirm-membership/:token" [] {:name :test/route46} handler) (ANY "/confirm-membership/:token" [] {:name :test/route46} handler)
@ -342,50 +352,155 @@
(ANY "/orgs/:org-id/topics" [] {:name :test/route40} handler) (ANY "/orgs/:org-id/topics" [] {:name :test/route40} handler)
(ANY "/schemas" [] {:name :test/route44} handler) (ANY "/schemas" [] {:name :test/route44} handler)
(ANY "/topics/:topic" [] {:name :test/route47} handler) (ANY "/topics/:topic" [] {:name :test/route47} handler)
(ANY "/topics" [] {:name :test/route50} handler))))) (ANY "/topics" [] {:name :test/route50} handler))))
(def opensensors-pedestal-routes
(map-tree/router
(table/table-routes
[["/v2/whoami" :get handler :route-name :test/route1]
["/v2/users/:user-id/datasets" :get handler :route-name :test/route2]
["/v2/public/projects/:project-id/datasets" :get handler :route-name :test/route3]
["/v1/public/topics/:topic" :get handler :route-name :test/route4]
["/v1/users/:user-id/orgs/:org-id" :get handler :route-name :test/route5]
["/v1/search/topics/:term" :get handler :route-name :test/route6]
["/v1/users/:user-id/invitations" :get handler :route-name :test/route7]
#_["/v1/orgs/:org-id/devices/:batch/:type" :get handler :route-name :test/route8]
["/v1/users/:user-id/topics" :get handler :route-name :test/route9]
["/v1/users/:user-id/bookmarks/followers" :get handler :route-name :test/route10]
["/v2/datasets/:dataset-id" :get handler :route-name :test/route11]
["/v1/orgs/:org-id/usage-stats" :get handler :route-name :test/route12]
["/v1/orgs/:org-id/devices/:client-id" :get handler :route-name :test/route13]
["/v1/messages/user/:user-id" :get handler :route-name :test/route14]
["/v1/users/:user-id/devices" :get handler :route-name :test/route15]
["/v1/public/users/:user-id" :get handler :route-name :test/route16]
["/v1/orgs/:org-id/errors" :get handler :route-name :test/route17]
["/v1/public/orgs/:org-id" :get handler :route-name :test/route18]
["/v1/orgs/:org-id/invitations" :get handler :route-name :test/route19]
["/v2/public/messages/dataset/bulk" :get handler :route-name :test/route20]
#_["/v1/users/:user-id/devices/bulk" :get handler :route-name :test/route21]
["/v1/users/:user-id/device-errors" :get handler :route-name :test/route22]
["/v2/login" :get handler :route-name :test/route23]
["/v1/users/:user-id/usage-stats" :get handler :route-name :test/route24]
["/v2/users/:user-id/devices" :get handler :route-name :test/route25]
["/v1/users/:user-id/claim-device/:client-id" :get handler :route-name :test/route26]
["/v2/public/projects/:project-id" :get handler :route-name :test/route27]
["/v2/public/datasets/:dataset-id" :get handler :route-name :test/route28]
["/v2/users/:user-id/topics/bulk" :get handler :route-name :test/route29]
["/v1/messages/device/:client-id" :get handler :route-name :test/route30]
["/v1/users/:user-id/owned-orgs" :get handler :route-name :test/route31]
["/v1/topics/:topic" :get handler :route-name :test/route32]
["/v1/users/:user-id/bookmark/:topic" :get handler :route-name :test/route33]
["/v1/orgs/:org-id/members/:user-id" :get handler :route-name :test/route34]
["/v1/users/:user-id/devices/:client-id" :get handler :route-name :test/route35]
["/v1/users/:user-id" :get handler :route-name :test/route36]
["/v1/orgs/:org-id/devices" :get handler :route-name :test/route37]
["/v1/orgs/:org-id/members" :get handler :route-name :test/route38]
#_["/v1/orgs/:org-id/members/invitation-data/:user-id" :get handler :route-name :test/route39]
["/v2/orgs/:org-id/topics" :get handler :route-name :test/route40]
["/v1/whoami" :get handler :route-name :test/route41]
["/v1/orgs/:org-id" :get handler :route-name :test/route42]
["/v1/users/:user-id/api-key" :get handler :route-name :test/route43]
["/v2/schemas" :get handler :route-name :test/route44]
["/v2/users/:user-id/topics" :get handler :route-name :test/route45]
["/v1/orgs/:org-id/confirm-membership/:token" :get handler :route-name :test/route46]
["/v2/topics/:topic" :get handler :route-name :test/route47]
["/v1/messages/topic/:topic" :get handler :route-name :test/route48]
["/v1/users/:user-id/devices/:client-id/reset-password" :get handler :route-name :test/route49]
["/v2/topics" :get handler :route-name :test/route50]
["/v1/login" :get handler :route-name :test/route51]
["/v1/users/:user-id/orgs" :get handler :route-name :test/route52]
["/v2/public/messages/dataset/:dataset-id" :get handler :route-name :test/route53]
["/v1/topics" :get handler :route-name :test/route54]
["/v1/orgs" :get handler :route-name :test/route55]
["/v1/users/:user-id/bookmarks" :get handler :route-name :test/route56]
["/v1/orgs/:org-id/topics" :get handler :route-name :test/route57]])))
(comment
(pedestal/find-route
(map-tree/router
(table/table-routes
[["/v1/orgs/:org-id/members/:user-id" :get (constantly "") :route-name :test/route34]
["/v1/orgs/:org-id/members/invitation-data/:user-id" :get (constantly "") :route-name :test/route39]]))
{:path-info "/v1/orgs/0/members/invitation-data/1" :request-method :get})
(require '[io.pedestal.http.route.definition.table :as table])
(require '[io.pedestal.http.route.map-tree :as map-tree])
(require '[io.pedestal.http.route.router :as pedestal])
(pedestal/find-route
(map-tree/router
(table/table-routes
[["/:a" :get (constantly "") :route-name ::ping]
["/evil/ping" :get (constantly "") :route-name ::evil-ping]]))
{:path-info "/evil/ping" :request-method :get}))
(doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [match (pedestal/find-route opensensors-pedestal-routes {:path-info route :request-method :get})]
(if-not match
(println route))))
(comment (comment
(bench opensensors-routes false) (bench opensensors-routes false)
(bench opensensors-routes true)) (bench opensensors-routes true))
(comment (comment
(doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [app (ring/ring-handler (reitit/router opensensors-routes))
match (app {:uri route :request-method :get})]
(if-not match
(println route))))
(doseq [route (valid-urls (reitit/router opensensors-routes))] (doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [match (bidi/match-route opensensors-bidi-routes route)] (let [match (bidi/match-route opensensors-bidi-routes route)]
(if-not match (if-not match
(println route))))) (println route))))
(comment
(let [ataraxy-routes (ataraxy/compile opensensors-ataraxy-routes)]
(doseq [route (valid-urls (reitit/router opensensors-routes))] (doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [match (ataraxy/matches ataraxy-routes {:uri route})] (let [match (ataraxy/matches opensensors-ataraxy-routes {:uri route})]
(if-not match (if-not match
(println route)))))) (println route))))
(comment
(doseq [route (valid-urls (reitit/router opensensors-routes))] (doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [match (opensensors-compojure-api-routes {:uri route :request-method :get})] (let [match (opensensors-compojure-api-routes {:uri route :request-method :get})]
(if-not match
(println route))))
(doseq [route (valid-urls (reitit/router opensensors-routes))]
(let [match (pedestal/find-route opensensors-pedestal-routes {:path-info route :request-method :get})]
(if-not match (if-not match
(println route))))) (println route)))))
(defn bench! [routes name f] (defn bench! [routes name f]
(System/gc) (System/gc)
(println) (println)
(title name) (suite name)
(println) (println)
(doseq [[path time] (bench-routes routes f)] (let [times (for [[path time] (bench-routes routes f)]
(println (format "%7s" time) "\t" path))) (do
(println (format "%7s" time) "\t" path)
time))]
(title (str "average: " (int (/ (reduce + times) (count times)))))))
(defn bench-all! [] (defn bench-all! []
(let [routes opensensors-routes (let [routes opensensors-routes
router (reitit/router routes) router (reitit/router routes)
reitit-f #(reitit/match-by-path router %) reitit-f #(reitit/match-by-path router %)
reitit-ring-f (let [app (ring/ring-handler (reitit/router opensensors-routes))]
#(app {:uri % :request-method :get}))
bidi-f #(bidi/match-route opensensors-bidi-routes %) bidi-f #(bidi/match-route opensensors-bidi-routes %)
ataraxy-f #(ataraxy/matches opensensors-ataraxy-routes {:uri %}) ataraxy-f #(ataraxy/matches opensensors-ataraxy-routes {:uri %})
compojure-api-f #(opensensors-compojure-api-routes {:uri % :request-method :get})] compojure-api-f #(opensensors-compojure-api-routes {:uri % :request-method :get})
(bench! routes "reitit" reitit-f) ;; 2958ns 11% pedestal-f #(pedestal/find-route opensensors-pedestal-routes {:path-info % :request-method :get})]
(bench! routes "bidi" bidi-f) ;; 18919ns 71%
(bench! routes "ataraxy" ataraxy-f) ;; 26461ns 100% (bench! routes "reitit" reitit-f) ;; 2538ns 10%
(bench! routes "compojure-api" compojure-api-f))) ;; 10463ns 40% (bench! routes "pedestal" pedestal-f) ;; 2737ns 11%
(bench! routes "reitit-ring" reitit-ring-f) ;; 2845ns 11%
(bench! routes "compojure-api" compojure-api-f) ;; 10215ns 41%
(bench! routes "bidi" bidi-f) ;; 19298ns 77%
(bench! routes "ataraxy" ataraxy-f) ;; 24950ns 100%
))
(comment (comment
(bench-all!)) (bench-all!))