2012-03-08 88 views
0

在我的特徵文件我有這樣的事情:NPE試圖讀取黃瓜JVM的表格數據(黃瓜的Clojure)

Scenario: Things 
    Given the table is empty 
    When I add a thing: 
     |   Foo | Bar |  Baz | 
     | 1293883200000 | 123.45 | 123456 | 
     | 1293884100000 | 123.45 | 123456 | 

任何想法?做錯了?在cucumber-jvm中的錯誤?

據我的步驟定義相匹配,但實際執行的是內部的代碼之前,我得到一個空指針異常:

java.lang.NullPointerException 
    at cucumber.runtime.StepDefinitionMatch.getGenericListType(StepDefinitionMatch.java:144) 
    at cucumber.runtime.StepDefinitionMatch.tableArgument(StepDefinitionMatch.java:135) 
    at cucumber.runtime.StepDefinitionMatch.transformedArgs(StepDefinitionMatch.java:103) 
    at cucumber.runtime.StepDefinitionMatch.runStep(StepDefinitionMatch.java:43) 
    at cucumber.runtime.Runtime.runStep(Runtime.java:220) 
    at cucumber.runtime.model.StepContainer.runStep(StepContainer.java:44) 
    at cucumber.runtime.model.StepContainer.runSteps(StepContainer.java:39) 
    at cucumber.runtime.model.CucumberScenario.run(CucumberScenario.java:32) 
    at cucumber.runtime.Runtime.run(Runtime.java:101) 
    at cucumber.runtime.Runtime.run(Runtime.java:85) 
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57) 
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) 
    at java.lang.reflect.Method.invoke(Method.java:616) 
    at clojure.lang.Reflector.invokeMatchingMethod(Reflector.java:92) 
    at clojure.lang.Reflector.invokeInstanceMethod(Reflector.java:30) 
    at leiningen.cucumber.util$run_cucumber_BANG_.invoke(util.clj:48) 
    at user$eval43.invoke(NO_SOURCE_FILE:1) 
    at clojure.lang.Compiler.eval(Compiler.java:6465) 
    at clojure.lang.Compiler.eval(Compiler.java:6455) 
    at clojure.lang.Compiler.eval(Compiler.java:6431) 
    at clojure.core$eval.invoke(core.clj:2795) 
    at clojure.main$eval_opt.invoke(main.clj:296) 
    at clojure.main$initialize.invoke(main.clj:315) 
    at clojure.main$null_opt.invoke(main.clj:348) 
    at clojure.main$main.doInvoke(main.clj:426) 
    at clojure.lang.RestFn.invoke(RestFn.java:421) 
    at clojure.lang.Var.invoke(Var.java:405) 
    at clojure.lang.AFn.applyToHelper(AFn.java:163) 
    at clojure.lang.Var.applyTo(Var.java:518) 
    at clojure.main.main(main.java:37) 
    at ✽.When I add a thing:(api.feature:9) 
+0

你可以包括你的黃瓜版本project.clj?和更多的上下文 – 2012-03-08 20:24:03

+0

是的,謝謝,我使用lein-cucumber,它使用info.cukes/cucumber-clojure版本「1.0.0.RC13」 – rplevy 2012-03-08 21:25:41

+0

它使用的不是最新的黃瓜clojure,所以爲了確保版本不是問題,我剛剛創建了一個使用RC20的lein-cucumber版本,安裝到我的本地maven中,並在我的項目中使用它。我仍然得到相同的結果。 – rplevy 2012-03-08 21:40:14

回答

3

看起來像一個錯誤cucumber.runtime.StepDefinitionMatchcode that deals with tabular data電話getGenericListType(int),進而解除引用StepDefinition#getParameterTypes()

不幸的是,cucumber.runtime.clojure.ClojureStepDefinition#getParameterTypes()always returnsnull,從而導致NPE。

我提交了一個issue指出這個問題。

+0

謝謝你做了深入Java的工作,弄清楚這一點! :) – rplevy 2012-03-09 22:16:54

+0

我發送了一個錯誤修復的拉取請求。同時,您可以使用https://github.com/nilswloka/cucumber-jvm/tree/table-data-for-clojure-stepdefs。 – 2012-03-12 13:40:37