加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

beforeEach在angularjs / requirejs场景中没有通过Karma / Jasmi

发布时间:2020-12-17 06:53:26 所属栏目:安全 来源:网络整理
导读:在本地运行我的单元测试工作正常,但在构建服务器上发生了最愚蠢的事情:有时他们通过,有时他们没有.主要代码: define(['angmock','someMore'],function () { describe('myController',function () { beforeEach(function () { console.log("Entry - Initial
在本地运行我的单元测试工作正常,但在构建服务器上发生了最愚蠢的事情:有时他们通过,有时他们没有.主要代码:

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包装器)为规范添加了更多移动部件.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读