2013-09-25 68 views
0

我正在處理一個包含Java類和Clojure文件的項目。目標是使用java測試Clojure文件。嘗試在cljunit中獲取名稱空間的var名稱時出錯

我使用Cljunit爲了這個目的:https://github.com/mikera/cljunit

我使用的代碼是下一個:

public class DemoClojureTest extends ClojureTest { 
@Override 
       public List<String> namespaces() { 
        @SuppressWarnings("unused") ArrayList<String> ns=new ArrayList<String>(); 
        ns.add("com.example.demo.helloWorld"); 
        return ns; 
       } 

    } 

而且Clojure的文件(helloWorld.clj)是:

(ns com.example.demo.helloWorld 
    (:use clojure.test)) 

(deftest test1 
    (is (= 1 3))) 

(deftest test2 
    (is (= 2 2))) 

當我嘗試執行DemoClojureTest時出現此錯誤:

錯誤atte命令空間獲取var名稱[com.example.demo.helloWorld]

java.io.FileNotFoundException: Could not locate com/example/demo/helloWorld__init.class or com/example/demo/helloWorld.clj on classpath: 
    at clojure.lang.RT.load(RT.java:432) 
    at clojure.lang.RT.load(RT.java:400) 
    at clojure.core$load$fn__4890.invoke(core.clj:5415) 
    at clojure.core$load.doInvoke(core.clj:5414) 
    at clojure.lang.RestFn.invoke(RestFn.java:408) 
    at clojure.core$load_one.invoke(core.clj:5227) 
    at clojure.core$load_lib.doInvoke(core.clj:5264) 
    at clojure.lang.RestFn.applyTo(RestFn.java:142) 
    at clojure.core$apply.invoke(core.clj:603) 
    at clojure.core$load_libs.doInvoke(core.clj:5298) 
    at clojure.lang.RestFn.applyTo(RestFn.java:137) 
    at clojure.core$apply.invoke(core.clj:603) 
    at clojure.core$require.doInvoke(core.clj:5381) 
    at clojure.lang.RestFn.invoke(RestFn.java:408) 
    at mikera.cljunit.core$get_test_var_names.invoke(core.clj:67) 
    at clojure.lang.Var.invoke(Var.java:415) 
    at mikera.cljunit.Clojure.getTestVars(Clojure.java:29) 
    at mikera.cljunit.NamespaceTester.<init>(NamespaceTester.java:19) 
    at mikera.cljunit.ClojureTester.<init>(ClojureTester.java:21) 
    at mikera.cljunit.ClojureRunner.<init>(ClojureRunner.java:16) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) 
    at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:39) 
    at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:27) 
    at java.lang.reflect.Constructor.newInstance(Constructor.java:513) 
    at org.junit.internal.builders.AnnotatedBuilder.buildRunner(AnnotatedBuilder.java:29) 
    at org.junit.internal.builders.AnnotatedBuilder.runnerForClass(AnnotatedBuilder.java:21) 
    at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59) 
    at org.junit.internal.builders.AllDefaultPossibilitiesBuilder.runnerForClass(AllDefaultPossibilitiesBuilder.java:26) 
    at org.junit.runners.model.RunnerBuilder.safeRunnerForClass(RunnerBuilder.java:59) 
    at org.junit.internal.requests.ClassRequest.getRunner(ClassRequest.java:26) 
    at com.intellij.junit4.JUnit4IdeaTestRunner.startRunnerWithArgs(JUnit4IdeaTestRunner.java:44) 
    at com.intellij.rt.execution.junit.JUnitStarter.prepareStreamsAndStart(JUnitStarter.java:195) 
    at com.intellij.rt.execution.junit.JUnitStarter.main(JUnitStarter.java:63) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25) 
    at java.lang.reflect.Method.invoke(Method.java:597) 
    at com.intellij.rt.execution.application.AppMain.main(AppMain.java:120) 

我在做什麼錯了?

+0

這是一個Java項目或者您在使用La Clojure嗎? – Jared314

+0

@ Jared314 La Clojure插件安裝在IDE(IntelliJ)中,但我不知道這個項目是否使用了它。 –

+1

這聽起來像是一個Intellij特定的類路徑問題。 clojure源文件夾是否被設置爲「sources」文件夾? – Jared314

回答

2

從堆棧跟蹤中,它看起來像IntelliJ測試運行器要麼在不包含Clojure源文件的類路徑中運行測試,要麼不包含它們在構建中。

確保您的Clojure文件所在的文件夾位於模塊設置中的「內容根目錄」下並標記爲「來源」或「測試來源」文件夾。

相關問題