NoraUI - 使用customDataProvider作为输入和输出时出现空指针异常

时间:2017-08-16 10:50:52

标签: java noraui

当我尝试将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的自定义方式。

1 个答案:

答案 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; } 类需要这两个方法来初始化用于编写结果的场景数据索引。

希望这有帮助