Reb*_*bin 6 clojure intellij-idea leiningen midje la-clojure
考虑下面的(最小)leiningen项目
./project.clj:
(defproject repro "0.1.0-SNAPSHOT"
:dependencies [[org.clojure/clojure "1.5.1"]
[midje "1.5.1"]])
Run Code Online (Sandbox Code Playgroud)
./repro/src/repro/core.clj:
(ns repro.core)
Run Code Online (Sandbox Code Playgroud)
./repro/test/repro/core_test.clj:
(ns repro.core-test
(:require [repro.core :refer :all]
[midje.sweet :refer :all]))
(facts "about numbers"
(fact "trivial"
1 => 1) )
Run Code Online (Sandbox Code Playgroud)
如果我安装了leiningen midje插件,它将在命令提示符下运行,如下所示:
lein clean
lein midje
~~> All checks (1) succeeded.
Run Code Online (Sandbox Code Playgroud)
但是,如果将leiningen项目导入Intellij 12.1.5 Community Edition,则会出现大量堆栈跟踪:
Exception in thread "main" java.lang.ExceptionInInitializerError
at java.lang.Class.forName0(Native Method)
at java.lang.Class.forName(Class.java:270)
...
at java.lang.reflect.Method.invoke(Method.java:606)
at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120)
Caused by: java.lang.NullPointerException
at java.util.concurrent.ConcurrentHashMap.hash(ConcurrentHashMap.java:333)
at java.util.concurrent.ConcurrentHashMap.get(ConcurrentHashMap.java:988)
at clojure.lang.Namespace.find(Namespace.java:188)
at clojure.core$find_ns.invoke(core.clj:3728)
at clojure.core$the_ns.invoke(core.clj:3760)
at clojure.core$ns_name.invoke(core.clj:3767)
at midje.Bootstrap$bootstrap.invoke(Bootstrap.clj:8)
at midje.sweet__init.load(Unknown Source)
at midje.sweet__init.<clinit>(Unknown Source)
... 37 more
Run Code Online (Sandbox Code Playgroud)
看起来La Clojure + Intellij找不到Midje的一些先决条件,这很奇怪,因为La Clojure正在从leiningen .m2目录中运行类路径。
我一直在寻找Intellij的midje插件,但到目前为止还没有运气。
我需要这个,因为尽管我很高兴只使用emacs + leiningen,但我的团队希望使用Intellij。
| 归档时间: |
|
| 查看次数: |
450 次 |
| 最近记录: |