当我尝试将CustomDataProvider用作输入和输出时,我遇到了问题。在场景中的某个时刻,抛出了NPE异常。
编辑1:我已阅读What is a NullPointerException, and how do I fix it?:我了解什么是NPE以及如何解决它。在我的案例中我不理解的是为什么在执行的那个时刻发生了一次,并且在我的情况下使用了这个特定的对象。我不是NoraUI框架的专家。当我查看现有的dataProvider时,他们从不操纵indexData对象,所以我也没有。我不知道它们是如何处理的以及它们何时被初始化。这就是为什么我问这个问题为什么会在这个时刻发生,以及我是否忘记了有经验的人。对不起,如果不清楚。这是一个与NoraUI框架更相关的问题,而不是纯Java框架。
例外:
使用CustomDataProvider,scenarioInitiator执行得很好:数据生成良好并写在Gherkin上。但就在场景发布之初,抛出异常:
[2017-08-16 15:37:28]: ********************************************************************************************************
[2017-08-16 15:37:28]: * *
[2017-08-16 15:37:28]: * Scénario: [@scenario] étape 1 sur 0 avec 0 erreur(s) et 0 alerte(s). Il reste 0s *
[2017-08-16 15:37:28]: * *
[2017-08-16 15:37:28]: ********************************************************************************************************
Failed scenarios:
steps/scenarios/scenario.feature:4 # Scenario: scenario
1 Scenarios (1 failed)
28 Steps (28 skipped)
5m52.930s
java.lang.NullPointerException
at noraui.exception.Result$Success.<init>(Result.java:32)
at noraui.application.steps.CucumberHooks.setUpScenario(CucumberHooks.java:44)
通过对调试的更多研究,似乎引发异常的确切行是 noraui.exception.Result的第一个构造函数中 for loop 的条件$ Success 对象:
public static class Success<O> extends Result {
private final O object;
private static final Logger logger = Logger.getLogger(Success.class.getName());
public Success(O object, String message) throws TechnicalException {
this.object = object;
this.message = message;
for (Integer i : Context.getDataInputProvider().getIndexData(Context.getCurrentScenarioData()).getIndexes()) {
Context.getDataOutputProvider().writeSuccessResult(i);
}
logger.info(message + " [" + success() + "]");
}
public O success() {
Optional<O> o = Optional.ofNullable(object);
return o.isPresent() ? o.get() : null;
}
}
我认为它与在DataProvider对象中声明的 IndexData 有关(由CustomDataProvider扩展,而后者又由我的customDataProvider扩展)。但我无法理解为什么它会失败,因为在我的情况下我使用了super方法,就像其他常见的DataProvider(Excel,DB等)一样。
自定义数据提供者:
我的自定义数据提供程序启动多次查询,其中一些根据第一个查询返回的内容进行修改。这些查询的最终结果存储在ArrayList<ArrayList<String>> dataTable
变量中。数据行如下:| Offer | Product | Items | Results |
所以我的问题是:
为什么使用我的自定义数据提供程序抛出此NPE而与其他DataProvider一样,它没有。因为我没有看到他们中的任何一个具有处理DataIndex的自定义方式。
答案 0 :(得分:2)
由于代码的这一部分,您的问题似乎发生了:
Sub
getIndexData为当前检索的Context.getCurrentScenarioData();
返回null如果您创建了DataInputProvider,则应该从Sup
扩展您的课程并覆盖getIndexData(Context.getCurrentScenarioData())
方法,如下所示:
CommonDataProvider
还应通过返回用作输入的数据行数(包括列名称行)来重新定义getModel()
方法。
实际上,/**
* {@inheritDoc}
*/
@Override
public Class<Model> getModel(String modelPackages) throws TechnicalException {
return null;
}
类需要这两个方法来初始化用于编写结果的场景数据索引。
希望这有帮助