mirror of
https://github.com/Hopiu/angular.js.git
synced 2026-03-21 00:40:24 +00:00
Couple of changes into angular.scenario runner: - add autotest config (runs tests when document ready) - update ObjectModel (forwards events) - use only one ObjectModel instance for all outputters - expose error msg and line number in ObjectModel.Spec and ObjectModel.Step - fix generating spec.ids - fix 'html' output so that it does not mutate ObjectModel Couple of changes into docs / generator: - rename copy -> copyTpl - move docs/static into docs/examples (to avoid conflict with jstd proxy) Running all docs e2e tests: ======================================================== 1/ compile angular-scenario, jstd-scenario-adapter >> rake compile 2/ build docs >> rake docs 3/ start jstd server >> ./server-scenario.sh 4/ capture some browser 5/ run node server to serve static content >> node ../lib/nodeserver/server.js 6/ run tests >> ./test-scenario.sh
125 lines
3.9 KiB
JavaScript
125 lines
3.9 KiB
JavaScript
describe('angular.scenario.output.html', function() {
|
|
var runner, model, spec, listeners;
|
|
var ui, context;
|
|
|
|
beforeEach(function() {
|
|
listeners = [];
|
|
spec = {
|
|
name: 'test spec',
|
|
definition: {
|
|
id: 10,
|
|
name: 'child',
|
|
children: [],
|
|
parent: {
|
|
id: 20,
|
|
name: 'parent',
|
|
children: []
|
|
}
|
|
}
|
|
};
|
|
step = {
|
|
name: 'some step',
|
|
line: function() { return 'unknown:-1'; }
|
|
};
|
|
runner = new angular.scenario.testing.MockRunner();
|
|
model = new angular.scenario.ObjectModel(runner);
|
|
context = _jQuery("<div></div>");
|
|
ui = angular.scenario.output.html(context, runner, model);
|
|
});
|
|
|
|
it('should create nested describe context', function() {
|
|
runner.emit('SpecBegin', spec);
|
|
expect(context.find('#describe-20 #describe-10 > h2').text()).
|
|
toEqual('describe: child');
|
|
expect(context.find('#describe-20 > h2').text()).toEqual('describe: parent');
|
|
expect(context.find('#describe-10 .tests > li .test-info .test-name').text()).
|
|
toEqual('test spec');
|
|
expect(context.find('#describe-10 .tests > li').hasClass('status-pending')).
|
|
toBeTruthy();
|
|
});
|
|
|
|
it('should add link on InteractiveWait', function() {
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('InteractiveWait', spec, step);
|
|
expect(context.find('.test-actions .test-title:first').text()).toEqual('some step');
|
|
expect(lowercase(context.find('.test-actions .test-title:last').html())).toEqual(
|
|
'waiting for you to <a href="javascript:resume()">resume</a>.'
|
|
);
|
|
});
|
|
|
|
it('should update totals when steps complete', function() {
|
|
// Failure
|
|
for (var i=0; i < 3; ++i) {
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepFailure', spec, step, 'error');
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
}
|
|
|
|
// Error
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('SpecError', spec, 'error');
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
// Error
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepError', spec, step, 'error');
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
// Success
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
expect(parseInt(context.find('#status-legend .status-failure').text(), 10)).
|
|
toEqual(3);
|
|
expect(parseInt(context.find('#status-legend .status-error').text(), 10)).
|
|
toEqual(2);
|
|
expect(parseInt(context.find('#status-legend .status-success').text(), 10)).
|
|
toEqual(1);
|
|
});
|
|
|
|
it('should update timer when test completes', function() {
|
|
// Success
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
// Failure
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepFailure', spec, step, 'error');
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
// Error
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('SpecError', spec, 'error');
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
context.find('#describe-10 .tests > li .test-info .timer-result').
|
|
each(function(index, timer) {
|
|
expect(timer.innerHTML).toMatch(/ms$/);
|
|
});
|
|
});
|
|
|
|
it('should include line if provided', function() {
|
|
runner.emit('SpecBegin', spec);
|
|
runner.emit('StepBegin', spec, step);
|
|
runner.emit('StepFailure', spec, step, 'error');
|
|
runner.emit('StepEnd', spec, step);
|
|
runner.emit('SpecEnd', spec);
|
|
|
|
var errorHtml = context.find('#describe-10 .tests li pre').html();
|
|
expect(errorHtml.indexOf('unknown:-1')).toEqual(0);
|
|
});
|
|
|
|
});
|