微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

JavaScript – Backbone.js在浏览器中使用Sinon Spies查看测试

我正在为Backbone View编写一个测试,以测试在获取模型后调用render函数.测试是:
beforeEach(function () {
    $('body').append('<div class="sidebar"></div>');
    profileView = new ProfileView();
});

it('should call the render function after the model has been fetched',function (done) {
    profileView.model = new usermodel({md5: 'd7263f0d14d66c349016c5eabd4d2b8c'});
    var spy = sinon.spy(profileView,'render');
    profileView.model.fetch({
        success: function () {
            sinon.assert.called(spy);
            done();
        }
    });   
});

我使用Sinon Spies将一个间谍对象附加到profileView视图对象的render函数.

视图是:

var ProfileView = Backbone.View.extend({
    el: '.sidebar',template: Hogan.compile(ProfileTemplate),model: new usermodel(),initialize: function () {
        this.model.bind('change',this.render,this);
        this.model.fetch();
    },render: function () {
        $(this.el).html(this.template.render());
        console.log("Profile Rendered");
        return this;
    }
});

在测试中调用提取后,更改事件将触发,并且视图的渲染函数正在被调用,但是Sinon间谍没有检测到渲染被调用并失败.

作为一个实验,我尝试在测试中调用render函数来查看Spy是否识别出它:

it('should call the render function after the model has been fetched','render');
    profileView.render();
    profileView.model.fetch({
        success: function () {
            sinon.assert.called(spy);
            done();
        }
    });   
});

在间谍侦测到被叫是在上述情况.

有人知道为什么间谍没有在初始测试中识别渲染调用吗?

解决方法

问题是,在构造视图期间,初始化函数将事件直接绑定到render函数.您无法使用间谍拦截此事件,因为在设置间谍之前已经发生绑定(您在构建之后执行此操作).

在构建视图之前,该解决方案是在原型上进行间谍.所以你必须将间谍移动到beforeEach,或将视图的构造移动到测试中.

设置间谍:

this.renderSpy = sinon.spy(ProfileView.prototype,'render');
this.view = new ProfileView();

然后,删除间谍:

ProfileView.prototype.render.restore()

然后这将会窥探“普通”的调用,以及来自模型的更改事件.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据复制操作的两种方式。‌在聊深浅拷贝之前咱得了解一下js中的两种数据类型:
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:重建二叉树、反向输出链表每个节点 题目 重建二叉树: 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前序遍历序列 {1,2,4,7,3,5,6,8} 和中序遍历序列 {
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须了解的知识点,现在迎来了ES6+的时代,因为箭头函数的出现,所以感觉有必要对 this 问题梳理一下,所以刚好总结一下JavaScript中this指向的问题。
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面
如何用js控制图片放大缩小
JS怎么获取当前时间戳
JS如何判断对象是否为数组
JS怎么获取图片当前宽高