测试期间的Carmine连接错误

时间:2016-08-14 08:45:26

标签: clojure compojure luminus compojure-api carmine

我有一个带有一些简单的compojure-api路线的luminus项目。 我添加~x ^ MOD与redis服务器通信,使用carmine宏(在services.clj中定义)来调用它,一切正常。

现在我正在尝试添加一些测试,但似乎redis连接在它们期间无法正常工作,因为我在wcar*收到此错误:

  

错误Carmine连接错误

     

clojure.lang.ExceptionInfo:Carmine连接错误{}

由于它在lein test e dev环境中运行,我认为这与prod环境中缺少env负载相关,但我没有找到一种解决它的方法。

这些是正在使用的代码的相关部分:

test.clj

test

services.clj

(ns app.test.handler
  (:require [clojure.test :refer :all]
            [ring.mock.request :refer :all]
            [app.handler :refer :all]))

(deftest test-app
  (testing "redis ping"
    (let [response ((app) (request :get "/api/redis-ping"))]
      (is (= 200 (:status response))))))

handler.clj

(ns app.routes.services
  (:require [ring.util.http-response :refer :all]
            [compojure.api.sweet :refer :all]
            [schema.core :as s]
            [app.config :refer [env]]
            [clojure.tools.logging :as log]
            [mount.core :refer [defstate]]
            [taoensso.carmine :as car :refer (wcar)]))

(defmacro wcar* [& body] `(car/wcar
                           {:spec {:host (:redis-host env) :port (:redis-port env)}}
                           ~@body))

(defapi service-routes
     (context "/api" []
           :tags ["myapi"]

         (GET "/redis-ping" []
               :return String
               :summary "A redis client test."
               (ok (wcar* (car/ping "hello"))))))

Profiles.clj

(ns app.handler
  (:require [compojure.core :refer [routes wrap-routes]]
            [app.routes.services :refer [service-routes]]
            [compojure.route :as route]
            [app.env :refer [defaults]]
            [mount.core :as mount]
            [app.middleware :as middleware]))

(mount/defstate init-app
                :start ((or (:init defaults) identity))
                :stop  ((or (:stop defaults) identity)))

(def app-routes
  (routes
    #'service-routes
    (route/not-found
      "page not found")))


(defn app [] (middleware/wrap-base #'app-routes))

Config.clj

{:profiles/dev  {:env {:redis-host "127.0.0.1" :redis-port 6381}}
:profiles/test {:env {:redis-host "127.0.0.1" :redis-port 6381}}}

使用在测试之前执行的(ns app.config (:require [cprop.core :refer [load-config]] [cprop.source :as source] [mount.core :refer [args defstate]])) (defstate env :start (load-config :merge [(args) (source/from-system-props) (source/from-env)])) 命令添加文本夹具。

添加到 test.clj

mount/start

1 个答案:

答案 0 :(得分:0)

您正在使用mount来管理应用程序状态生命周期。我认为您未在测试中调用(mount/start),因此您的app.config/env状态未正确初始化。另一方面,当您启动应用程序时,可能会调用(mount/start),因此它正常工作。