乡绅正在打破其他测试

时间:2013-09-15 10:34:53

标签: javascript requirejs jasmine karma-runner squirejs

我正在使用Karma,Jasmine,Jasmine.Async,Sinon和Chai。

好消息......这个测试工作正常。依赖性被嘲笑,间谍被调用,故意破坏测试对象导致测试失败。

define(['chai', 'squire'], function (chai, Squire) {

    var should = chai.should(),
        async = new AsyncSpec(this),
        subject, injector = new Squire();

    describe('EventsView', function () {

        describe('when an event is clicked', function () {
            var mockModel, stub;

            async.beforeEach(function (done) {
                setFixtures('<div id="screen"></div>');

                mockModel = {
                    toJSON: function () {
                        return {
                            dimensions: "hu1 vu2",
                            events: [{
                                date: "8/29/2013",
                                id: "8923",
                                title: "Fancy Show",
                                venue: "Lovely venue",
                            }, {
                                date: "8/29/2013",
                                id: "9034",
                                title: "Exciting Game",
                                venue: "Lovely stadium"
                            }],
                            id: 3566,
                            kind: "events",
                            title: "Top events this week"
                        };
                    },
                    fetch: function () {}
                };
                stub = sinon.stub();
                injector.mock('tiles/events-tile/events-detail-model', Squire.Helpers.constructs({
                    fetch: stub
                }));
                injector.require(["tiles/events-tile/events-view"], function (ev) {
                    subject = new ev(mockModel);
                    done();
                });
            });

            async.afterEach(function (done) {
                injector.clean();
                injector.remove();
                done();
            });


            async.it('should attempt to fetch the event details', function (done) {
                $('#screen').html(subject.$el);
                $('.event').first().click();
                stub.called.should.be.true;
                done();
            });
        });
    });
});

坏消息......以前很好的其他测试的大量负载现在因为奇怪的原因而失败。例如: Error: Backbone.history has already been startedTypeError: 'undefined' is not an object (evaluating 'Backbone.Validation.mixin')

如果我注释掉片段

injector.require(["tiles/events-tile/events-view"], function (ev) {
  subject = new ev(mockModel);
    done();
});

然后其他测试再次起作用。我曾经有类似的事情发生在此之前,它通常是由于一个没有得到恢复的sinon模拟。 injector.clean()电话似乎没有提供我希望的灵丹妙药。

2 个答案:

答案 0 :(得分:5)

根据我的经验,乡绅造成的麻烦比解决的更令人头疼。你在使用任何jQuery插件吗?我发现他们与乡绅的关系并不好,可能导致后续测试失败。如果是这种情况,请查看this blog,了解如何处理该问题。

然而,我的建议是彻底抛弃乡绅。使用sinon并创建自己的实用程序来精确模拟所需内容不仅应该使异步测试再次同步(测试中的代码是同步的),而且还会鼓励创建更多可测试的代码。它还应该帮助您更深入地理解您的代码和库 - 在不实际触发路由的情况下对Backbone.history执行路由操作是一个很好的练习,并且可以添加到您的测试库中。

答案 1 :(得分:3)

问题出在非AMD模块上。如果我在Squire创建新上下文时正确记得它将在全局命名空间中创建非AMD模块的新实例。结果是您的代码和测试将引用不同的对象。我想通过这样做来设法解决了这个问题:

var injector = new Squire();
injector.mock("backbone", function() {
  return Backbone;
});

Squire应该更好地处理非AMD模块。