以下是相关代码。
define (require) ->
Backbone = require 'backbone'
require 'backbone-deferred'
class Data extends Backbone.Deferred.Model
urlRoot: 'data'
parse: (resp) ->
resp.record or resp
isValid: ->
@get 'valid'
# Newly introduced
dataUrl: ->
@get('data_url')?.replace /abc/, ''
这是单元测试
define (require) ->
Data = require 'model/Data'
describe 'dataurl', ->
describe 'No change', ->
data = new Data id: '123', name: 'Dummy', data_url: 'https://m/a.png'
expect(data.dataUrl()).to.equal('https://m/a.png')
由于某些原因,测试不是由mocha运行。
我正在使用这个html来推动测试
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Mocha Tests</title>
<link rel="stylesheet" href="../bower_components/mocha/mocha.css" type="text/css" media="screen" title="Tests for {%= name %}" charset="utf-8">
</head>
<body>
<div id="mocha"></div>
<script src="../bower_components/mocha/mocha.js" type="text/javascript" charset="utf-8"></script>
<script src="../bower_components/chai/chai.js" type="text/javascript" charset="utf-8"></script>
<script src="../bower_components/requirejs/require.js" type="text/javascript" charset="utf-8"></script>
<!-- Requirejs configuration -->
<script src="../temp/local/scripts/config.js" type="text/javascript" charset="utf-8"></script>
<script type="text/javascript" charset="utf-8">
// Dumping console messages to /dev/null to avoid parsing error
// when grunt:mocha_phantomjs is run
if (navigator.userAgent.indexOf('PhantomJS') >= 0) {
var log = console.log
console.log = function(message) {
if (message.indexOf('<') === 0) {
log.apply(this, Array.prototype.slice.call(arguments))
}
}
}
// Mixpanel is not loaded for unit testing.
// Redirecting mixpanel to /dev/null.
window.mixpanel = {
track: function() {}
};
require.config({
baseUrl: "../temp/local/scripts",
shim: {
'chai-jquery': {
deps: ['jquery']
},
'sinon': {
exports: 'sinon'
}
},
paths: {
// Aliasing path to find the specs
'specs': '../../specs',
'sinon' : '../../../bower_components/sinon/lib/sinon',
'sinon-chai' : '../../../bower_components/sinon-chai/lib/sinon-chai',
'chai-jquery': '../../../bower_components/chai-jquery/chai-jquery',
'handlebars' : '../../../bower_components/handlebars/handlebars',
}
});
runTests = function() {
// Ensuring that jquery and chai-jquery are loaded
require(
['jquery', 'chai-jquery', 'sinon-chai', 'handlebars'],
function($, jqueryChai, sinonChai, Handlebars) {
// Registering testing style in globals for easy access
window.expect = chai.expect;
chai.use(jqueryChai);
chai.use(sinonChai)
mocha.setup({
ui: 'bdd',
ignoreLeaks: true
});
// Protect from barfs
console = window.console || function() {};
// Don't track
window.notrack = true;
// Helper... not really needed but in case we want to do something fancy
var runMocha = function() {
mocha.run();
};
require([
// Many other tests; removed for clarity
'specs/data.spec'
], function() {
// For xUnit and code coverage reports, we run the tests
// using mocha-phantomjs runner.
if (window.mochaPhantomJS) {
mochaPhantomJS.run();
}
else {
mocha.run();
}
});
});
}
</script>
</body>
</html>
这是grunt测试任务的输出
Running "mocha:default" (mocha) task
Testing: test/index.html
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․․
․․․․․․․․․․․
1081 passing (9s)
>> 1081 passed! (9.17s)
我的问题是:
1)添加新测试后,测试次数完全改变。新测试没有被提取的可能原因是什么?
2)如果我故意在单元测试中引入错误,则会在测试失败的情况下导致错误:
Warning: PhantomJS timed out, possibly due to a missing Mocha run() call. Use --force to continue.
我确信它与测试有关,但没有足够的信息来诊断问题。如何打开日志记录或获取其他信息?
答案 0 :(得分:1)
您的测试用例应使用describe
函数而不是define (require) ->
Data = require 'model/Data'
describe 'dataurl', ->
it 'No change', ->
data = new Data id: '123', name: 'Dummy', data_url: 'https://m/a.png'
expect(data.dataUrl()).to.equal('https://m/a.png')
(用于对测试进行分组)来定义
it
我创建了this jdfiddle,因此您可以看到与原始定义的差异。
如果在测试中引入错误,如果未在ShowWhatIWant(true, false, false);
private string ShowWhatIWant(bool showMinutes, bool showSeconds, bool showMiliSeconds)
{
string text = string.Format("{0:00}", Math.Floor(elapsed.TotalHours));
if(showMinutes)
{
text += string.Format(":{0:00}", elapsed.Minutes);
}
if(showSeconds)
{
text += string.Format(":{0:00}", elapsed.Seconds);
}
if(showMiliSeconds)
{
text += string.Format(":{0:00}", elapsed.Milliseconds);
}
return text;
}
函数内定义测试,则会影响整个测试运行。您可以在other fiddle中查看它(您会注意到第二个测试在错误的定义测试中的错误之后没有运行)