5

我有一组使用 Mocha 和 jsdom 运行的 Web 应用程序的单元测试。我正在使用 jsdom 而不是真正的浏览器,以便让我的 mocha 单元测试尽可能快地运行,我们将进行运行 selenium 的集成测试,以测试更多真正的浏览器内容。我也在使用 istanbul 生成代码覆盖率报告,但是有些代码无法使用 Mocha/jsdom 进行测试。以这段代码为例:

var myObject = {
    //...

    /* istanbul ignore next */
    _resizeEvent: function() {
        if(this.props.isActive) {
            //.9 match the scss max-height: 90%, this value needs to be kept in sync with the sass code
            this.getDOMNode().querySelector('.modal__content').style.maxHeight = Math.floor(window.innerHeight * .9) + 'px';
            this.getDOMNode().querySelector('.modal__content').style.maxWidth = Math.floor(window.innerWidth * .9) + 'px';
            this._centerPosition();
        }
    },

    //...
}

由于没有真正的浏览器,这种方法无法真正用jsdom进行测试。我遇到的问题是,即使我有/* istanbul ignore next */before 对象方法,它仍然告诉我方法内部的代码没有被覆盖(而不是只是告诉我它被忽略了)。

有没有一种简单的方法可以完全忽略对象方法及其所有内容,而不必/* istanbul ignore next */在方法中的每个语句之前添加?

4

2 回答 2

6

以下对我有用:

var myObject = {
//...
};

/* istanbul ignore next */
myObject._resizeEvent = function () {
//...
};
于 2015-02-11T14:44:46.680 回答
1

也面临这个问题,幸运的是不需要 myObject._resizeEvent。您只需要确保忽略 next 位于函数名称旁边。

以下作品:

var myObject = {
    _resizeEvent /* istanbul ignore next */: function() {

    },
}
于 2018-11-21T11:10:25.513 回答