Merge branch 'master' of github.com:hylang/hy into paultag/bugfix/python3.4
This commit is contained in:
commit
f28bf41f8d
@ -1,31 +1,30 @@
|
|||||||
;;; Meth
|
;;; Meth
|
||||||
;; based on paultag's meth library to access a Flask based application
|
;; based on paultag's meth library to access a Flask based application
|
||||||
|
|
||||||
(defmacro route [name path params code]
|
(defmacro route-with-methods [name path methods params &rest code]
|
||||||
"Default get request"
|
|
||||||
`(let [[deco (.route app ~path)]]
|
|
||||||
(with-decorator deco
|
|
||||||
(defn ~name ~params ~@code))))
|
|
||||||
|
|
||||||
(defmacro route-with-methods [name path params code methods]
|
|
||||||
"Same as route but with an extra methods array to specify HTTP methods"
|
"Same as route but with an extra methods array to specify HTTP methods"
|
||||||
`(let [[deco (kwapply (.route app ~path)
|
`(let [[deco (kwapply (.route app ~path)
|
||||||
{"methods" ~methods})]]
|
{"methods" ~methods})]]
|
||||||
(with-decorator deco
|
(with-decorator deco
|
||||||
(defn ~name ~params ~@code))))
|
(defn ~name ~params
|
||||||
|
(progn ~@code)))))
|
||||||
|
|
||||||
;; Some macro examples
|
;; Some macro examples
|
||||||
(defmacro post-route [name path params code]
|
(defmacro route [name path params &rest code]
|
||||||
|
"Get request"
|
||||||
|
`(route-with-methods ~name ~path ["GET"] ~params ~@code))
|
||||||
|
|
||||||
|
(defmacro post-route [name path params &rest code]
|
||||||
"Post request"
|
"Post request"
|
||||||
`(route-with-methods ~name ~path ~params ~code ["POST"]))
|
`(route-with-methods ~name ~path ["POST"] ~params ~@code))
|
||||||
|
|
||||||
(defmacro put-route [name path params code]
|
(defmacro put-route [name path params &rest code]
|
||||||
"Put request"
|
"Put request"
|
||||||
`(route-with-methods ~name ~path ~params ~code ["PUT"]))
|
`(route-with-methods ~name ~path ["PUT"] ~params ~@code))
|
||||||
|
|
||||||
(defmacro delete-route [name path params code]
|
(defmacro delete-route [name path params &rest code]
|
||||||
"Delete request"
|
"Delete request"
|
||||||
`(route-with-methods ~name ~path ~params ~code ["DELETE"]))
|
`(route-with-methods ~name ~path ["DELETE"] ~params ~@code))
|
||||||
|
|
||||||
|
|
||||||
;;; Simple example application
|
;;; Simple example application
|
||||||
@ -34,7 +33,7 @@
|
|||||||
;; (import [flask [Flask]])
|
;; (import [flask [Flask]])
|
||||||
;; (setv app (Flask "__main__"))
|
;; (setv app (Flask "__main__"))
|
||||||
|
|
||||||
;; (require methy)
|
;; (require hy.contrib.meth)
|
||||||
|
|
||||||
;; (print "setup / with GET")
|
;; (print "setup / with GET")
|
||||||
;; (route get-index "/" [] (str "Hy world!"))
|
;; (route get-index "/" [] (str "Hy world!"))
|
||||||
|
@ -14,3 +14,4 @@ from .native_tests.core import * # noqa
|
|||||||
from .native_tests.reader_macros import * # noqa
|
from .native_tests.reader_macros import * # noqa
|
||||||
from .native_tests.with_test import * # noqa
|
from .native_tests.with_test import * # noqa
|
||||||
from .native_tests.contrib.anaphoric import * # noqa
|
from .native_tests.contrib.anaphoric import * # noqa
|
||||||
|
from .contrib.test_meth import * # noqa
|
||||||
|
0
tests/contrib/__init__.hy
Normal file
0
tests/contrib/__init__.hy
Normal file
54
tests/contrib/test_meth.hy
Normal file
54
tests/contrib/test_meth.hy
Normal file
@ -0,0 +1,54 @@
|
|||||||
|
(require hy.contrib.meth)
|
||||||
|
|
||||||
|
(defclass FakeMeth []
|
||||||
|
"Mocking decorator class"
|
||||||
|
[[rules {}]
|
||||||
|
[route (fn [self rule &kwargs options]
|
||||||
|
(fn [f]
|
||||||
|
(assoc self.rules rule (, f options))
|
||||||
|
f))]])
|
||||||
|
|
||||||
|
|
||||||
|
(defn test_route []
|
||||||
|
(let [[app (FakeMeth)]]
|
||||||
|
(route get-index "/" [] (str "Hy world!"))
|
||||||
|
(setv app-rules (getattr app "rules"))
|
||||||
|
(assert (in "/" app-rules))
|
||||||
|
(let [[(, rule-fun rule-opt) (get app-rules "/")]]
|
||||||
|
(assert (not (empty? rule-opt)))
|
||||||
|
(assert (in "GET" (get rule-opt "methods")))
|
||||||
|
(assert (= (getattr rule-fun "__name__") "get_index"))
|
||||||
|
(assert (= "Hy world!" (rule-fun))))))
|
||||||
|
|
||||||
|
(defn test_post_route []
|
||||||
|
(let [[app (FakeMeth)]]
|
||||||
|
(post-route get-index "/" [] (str "Hy world!"))
|
||||||
|
(setv app-rules (getattr app "rules"))
|
||||||
|
(assert (in "/" app-rules))
|
||||||
|
(let [[(, rule-fun rule-opt) (get app-rules "/")]]
|
||||||
|
(assert (not (empty? rule-opt)))
|
||||||
|
(assert (in "POST" (get rule-opt "methods")))
|
||||||
|
(assert (= (getattr rule-fun "__name__") "get_index"))
|
||||||
|
(assert (= "Hy world!" (rule-fun))))))
|
||||||
|
|
||||||
|
(defn test_put_route []
|
||||||
|
(let [[app (FakeMeth)]]
|
||||||
|
(put-route get-index "/" [] (str "Hy world!"))
|
||||||
|
(setv app-rules (getattr app "rules"))
|
||||||
|
(assert (in "/" app-rules))
|
||||||
|
(let [[(, rule-fun rule-opt) (get app-rules "/")]]
|
||||||
|
(assert (not (empty? rule-opt)))
|
||||||
|
(assert (in "PUT" (get rule-opt "methods")))
|
||||||
|
(assert (= (getattr rule-fun "__name__") "get_index"))
|
||||||
|
(assert (= "Hy world!" (rule-fun))))))
|
||||||
|
|
||||||
|
(defn test_delete_route []
|
||||||
|
(let [[app (FakeMeth)]]
|
||||||
|
(delete-route get-index "/" [] (str "Hy world!"))
|
||||||
|
(setv app-rules (getattr app "rules"))
|
||||||
|
(assert (in "/" app-rules))
|
||||||
|
(let [[(, rule-fun rule-opt) (get app-rules "/")]]
|
||||||
|
(assert (not (empty? rule-opt)))
|
||||||
|
(assert (in "DELETE" (get rule-opt "methods")))
|
||||||
|
(assert (= (getattr rule-fun "__name__") "get_index"))
|
||||||
|
(assert (= "Hy world!" (rule-fun))))))
|
Loading…
x
Reference in New Issue
Block a user