From 4810446185a566b58805fb9b0cfd7a51fd3d6cbf Mon Sep 17 00:00:00 2001 From: Craig Taub Date: Fri, 27 Jan 2017 23:26:33 +0000 Subject: [PATCH] Increase tests coverage for doc reporter --- test/reporters/doc.spec.js | 148 +++++++++++++++++++++++++++++++++++++ 1 file changed, 148 insertions(+) create mode 100644 test/reporters/doc.spec.js diff --git a/test/reporters/doc.spec.js b/test/reporters/doc.spec.js new file mode 100644 index 0000000000..29a86e21e1 --- /dev/null +++ b/test/reporters/doc.spec.js @@ -0,0 +1,148 @@ +'use strict'; + +var reporters = require('../../').reporters; +var Doc = reporters.Doc; + +describe('Doc reporter', function () { + var stdout; + var stdoutWrite; + var runner = {}; + beforeEach(function () { + stdout = []; + stdoutWrite = process.stdout.write; + process.stdout.write = function (string) { + stdout.push(string); + }; + }); + + describe('on suite', function() { + describe('if suite root does not exist', function() { + var expectedTitle = 'expectedTitle'; + var suite = { + root: false, + title: expectedTitle + } + it('should log html with expected header', function () { + runner.on = function (event, callback) { + if (event === 'suite') { + callback(suite); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + var expectedArray = [ + '
\n', + '

' + expectedTitle + '

\n', + '
\n' + ]; + stdout.should.deepEqual(expectedArray) + }); + }); + describe('if suite root does exist', function() { + var suite = { + root: true + } + it('should not log any html', function () { + runner.on = function (event, callback) { + if (event === 'suite') { + callback(suite); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + stdout.should.be.empty(); + }); + }); + }); + + describe('on suite end', function() { + describe('if suite root does not exist', function() { + var expectedTitle = 'expectedTitle'; + var suite = { + root: false, + title: expectedTitle + } + it('should log expected html', function () { + runner.on = function (event, callback) { + if (event === 'suite end') { + callback(suite); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + var expectedArray = [ + '
\n', '
\n' + ]; + stdout.should.deepEqual(expectedArray) + }); + }); + describe('if suite root does exist', function() { + var suite = { + root: true + } + it('should not log any html', function () { + runner.on = function (event, callback) { + if (event === 'suite end') { + callback(suite); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + stdout.should.be.empty(); + }); + }); + }); + + describe('on pass', function() { + var expectedTitle = 'some tite'; + var expectedBody = 'some body'; + var test = { + title: expectedTitle, + body: expectedBody, + slow: function () { + return ''; + } + } + it('should log expected html', function () { + runner.on = function (event, callback) { + if (event === 'pass') { + callback(test); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + var expectedArray = [ + '
' + expectedTitle + '
\n', + '
' + expectedBody + '
\n' + ]; + stdout.should.deepEqual(expectedArray) + }); + }); + + describe('on fail', function() { + var expectedTitle = 'some tite'; + var expectedBody = 'some body'; + var test = { + title: expectedTitle, + body: expectedBody, + slow: function () { + return ''; + } + } + it('should log expected html', function () { + runner.on = function (event, callback) { + if (event === 'fail') { + callback(test); + } + } + var doc = new Doc(runner); + process.stdout.write = stdoutWrite; + var expectedArray = [ + '
' + expectedTitle + '
\n', + '
' + expectedBody + '
\n', + '
undefined
\n' + ]; + stdout.should.deepEqual(expectedArray) + }); + }); +});