Mocha.js - 递归测试失败,但个人很好

时间:2015-03-04 02:31:26

标签: reactjs mocha

我有像这样的mocha.opts:

test/mocha/*.js
--recursive
--globals reactModulesToStub
--check-leaks
--compilers .:test/jsx-compiler.js
--reporter nyan

并且有两个测试在单独调用时传递,但是使用递归选项失败。我错过了什么吗?

例如,如果我在这个单一测试上运行mocha,没问题,但在同一目录中添加类似的测试将导致所有测试失败。

/** @jsx React.DOM */
//tests/app/loginstatus-test.js

var React = require('react/addons'),
    assert = require('assert'),
    sinon = require('sinon'),
    stubs = (function(){
        global.reactModulesToStub = [
            'TestClass.js'
        ];
    })(),
    MyComponent = require('../../app/modules/LoginStatus.jsx'),
    TestUtils = React.addons.TestUtils,
    TestContext = require('./../lib/TestContext').getRouterComponent(MyComponent),
    component = TestContext.component,
    dom = TestContext.dom,
    flux = TestContext.flux;

describe('LoginStatus', function() {

    it('renders the LoginStatus class', function() {
        TestUtils.findRenderedDOMComponentWithClass(
            component, 'LoginStatus');
    });

    it('when mounted and clicked, should call AppActions.showPopupModal', function() {
        sinon.spy(flux.actions.AppActions, "showPopupModal");
        TestUtils.Simulate.click(component.refs.loginStatusText.getDOMNode());
        assert(flux.actions.AppActions.showPopupModal.calledOnce);
    });
});

1 个答案:

答案 0 :(得分:0)

这是命名空间问题。我没有意识到Mocha将所有描述归入同一名称空间,如果你需要在测试之间使用干净的变量,将它们放入it();这里是一个很好的例子,说明如何做我想做的事情。做之前。

https://github.com/adjavaherian/mocha-react