首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何模拟sqlKorma?

如何模拟sqlKorma?
EN

Stack Overflow用户
提问于 2018-02-27 17:33:31
回答 1查看 108关注 0票数 0

我不熟悉Clojure中mocking是如何工作的。具体地说,我不确定应该如何测试实现sqlKorma查询或对数据库的调用的函数?理想情况下,我希望能够在测试中模拟sqlKorma。

代码语言:javascript
复制
(defn fetch [id]
(->
    (korma/select* :my-table)
    (korma/where {:id id})
    (korma/exec)))

(defn retrieve [id]
  (->
    (fetch id)
    (ring/response)))

我正在使用Speclj来测试我的应用程序。

代码语言:javascript
复制
(describe "item"
      (it "is fetched"
          (let [fetched (fetch :test-case)] ;here I want to be able to mock sqlKorma and return an array of 1.
          (should= (count fetch) 1)))

      (it "is retrieved"
          (let [retrieved (retrieve :test-case)]
          (should= (get retrieved :status) 200))))
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-02-27 18:05:31

有几种方法。一种方法是使用不同的数据库进行测试。例如内存数据库中的H2。这是首选,因为您不需要mocking,而且您还需要测试您的SQL。如果您真的想模拟您的fetch函数,可以使用with-redefs

代码语言:javascript
复制
(defn foo [] [{:foo "bar"}])
(foo) ;;=> [{:foo "bar"}]
(with-redefs [foo (fn [] [{:something "else"}])] (foo))
 ;;=> [{:something "else"}]
(foo) ;;=> [{:foo "bar"}]

https://clojuredocs.org/clojure.core/with-redefs

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49005345

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档