beforeEach在angularjs / requirejs场景中没有通过Karma / Jasmine调用

前端之家收集整理的这篇文章主要介绍了beforeEach在angularjs / requirejs场景中没有通过Karma / Jasmine调用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在本地运行我的单元测试工作正常,但在构建服务器上发生了最愚蠢的事情:有时他们通过,有时他们没有.主要代码

define(['angmock','someMore'],function () {
    describe('myController',function () {
        beforeEach(function () {
        console.log("Entry - Initializing modules...");
        module('module1');
        module('module2');
        console.log("Exit - Initializing modules...");
    });

    var scope,controller;
    beforeEach(inject(function ($rootScope,$controller) {
        console.log("Entry - Creating scope...");

        scope = $rootScope.$new();
        controller = $controller('myController',{
            $scope: scope
        });

        console.log("Exit - Creating scope...");
    }));

    it('should test something',function () {
        console.log("Entry - Test A");
        scope.myImportantAssignment = variableName;
        ...
        console.log("Exit - Test A");
    });
...

在构建服务器日志中,我有时可以阅读:

TypeError: undefined is not an object (evaluating
‘scope.myImportantAssignment = variableName’)

在控制台上我可以读到:

>日志:’进入 – 初始化模块……’
>日志:’退出 – 初始化模块……’
>日志:’进入 – 测试A’

这可能表明第二个beforeEach根本没有被调用,因此范围没有被初始化.但为什么?在我看来,处理应该像:

>在每个1之前
>在每个2之前
>它

但事实似乎并非如此.是不是有异步问题?非常感谢任何一点提示,因为如果它们有时会失败,我根本无法使用这些测试……

解决方法

没有可以解释问题的竞争条件,块是同步的并且总是按顺序运行.如果应用程序默默地无法自举并注入注入,则可能会发生这种情况.

控制台中应该有错误,但PhantomJS以吞咽错误而闻名,将Karma启动器更改为Chrome可能会改善错误输出.

从beforeEach移动注入到它也可以帮助找到问题,它使规范失败而不是失败的期望,但是使错误导致此期望失败.

在单元测试中,应用程序单元进行测试,其他所有内容都应该被模拟,具有额外的依赖关系(用于Kendo UI的Angular包装器)为规范添加了更多移动部件.

猜你在找的Angularjs相关文章