编程语言
首页 > 编程语言> > javascript – 使用Marionette.CompositeView进行单元测试

javascript – 使用Marionette.CompositeView进行单元测试

作者:互联网

通过使用jasmine,我试图测试一个返回Marionette.CompositeView的javascript模块.

这是javascript模块(2)和javascript单元测试(1).

我的问题是如何从(1)访问渲染的视图?
有关详细信息,请参阅代码注释.

P.S:
1)javascript模块可以生成正确的渲染视图.
2)当我运行测试时,javascript控制台给出了以下错误:backbone.marionette.min.js:9

Uncaught NoTemplateError: Could not find template: 'function (context, options) {
    if (!compiled) {
      compiled = compile();
    }
    return compiled.call(this, context, options);
  }' 

3)因为我使用把手,所以我用这种方式重写了Marionette.Renderer.render:

enter code here
define([
    'marionette'
], function (Marionette) {
    Marionette.Renderer.render = function (template, data) {
        return template(data);
    };
});

(1)

(function () {
    'use strict';
    define([
        // some code
    ], function (MyView) {
        describe('Layout App - Header View ', function () {
            beforeEach(function () {
                this.view = new MyView({
                    currentUser: new Backbone.Model()
                });
            });

            describe('Instantiation', function () {
                it('should create a div element', function () {
                    expect(this.view.el.nodeName).toEqual('DIV'); // it works
                });

            });

            describe("Rendering", function () {

                it("returns the view object", function () {
                    console.log(this.view.render()); // undefined // why?
                    expect(this.view.render()).toEqual(this.view); // it fails
                });
            });
        });
    });
});

(2)

define([
    // some code
], function (myTemplate, MyItemView) {
    return Marionette.CompositeView.extend({
        template: myTemplate,
        itemView: MyItemView,
        // some code
    });

});

解决方法:

在其上调用render方法,就像使用任何其他骨干视图一样


            beforeEach(function () {
                this.view = new MyView({
                    currentUser: new Backbone.Model()
                });

                // render it
                this.view.render();
            });

标签:javascript,backbone-js,jasmine,marionette
来源: https://codeday.me/bug/20190709/1414150.html