Skip to content

Commit

Permalink
suite.js corrections and new tests
Browse files Browse the repository at this point in the history
  • Loading branch information
juergba committed Jan 3, 2019
1 parent 82faa1b commit dc65b3d
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 19 deletions.
17 changes: 10 additions & 7 deletions lib/suite.js
Original file line number Diff line number Diff line change
Expand Up @@ -41,16 +41,18 @@ exports.create = function(parent, title) {
};

/**
* Initialize a new `Suite` with the given `title`, `ctx` and `root`. Derived from [EventEmitter](https://nodejs.org/api/events.html#events_class_eventemitter)
* Constructs a new `Suite` instance with the given `title`, `ctx`, and `isRoot`.
*
* @memberof Mocha
* @public
* @class
* @param {string} title
* @param {Context} parentContext
* @param {boolean} root
* @extends EventEmitter
* @memberof Mocha
* @see {@link https://nodejs.org/api/events.html#events_class_eventemitter|EventEmitter}
* @param {string} title - Suite title.
* @param {Context} parentContext - Parent context instance.
* @param {boolean} isRoot - Whether this is the root suite.
*/
function Suite(title, parentContext, root) {
function Suite(title, parentContext, isRoot) {
if (!utils.isString(title)) {
throw createInvalidArgumentTypeError(
'Suite argument "title" must be a string. Received type "' +
Expand All @@ -71,7 +73,7 @@ function Suite(title, parentContext, root) {
this._beforeAll = [];
this._afterEach = [];
this._afterAll = [];
this.root = root || false;
this.root = isRoot === true;
this._timeout = 2000;
this._enableTimeouts = true;
this._slow = 75;
Expand Down Expand Up @@ -327,6 +329,7 @@ Suite.prototype.afterEach = function(title, fn) {
*/
Suite.prototype.addSuite = function(suite) {
suite.parent = this;
suite.root = false;
suite.timeout(this.timeout());
suite.retries(this.retries());
suite.enableTimeouts(this.enableTimeouts());
Expand Down
35 changes: 23 additions & 12 deletions test/unit/suite.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -302,6 +302,27 @@ describe('Suite', function() {
});
});

describe('.create()', function() {
before(function() {
this.first = new Suite('Root suite', {}, true);
this.second = new Suite('RottenRoot suite', {}, true);
this.first.addSuite(this.second);
});

it('sets second root property to false', function() {
expect(this.second.parent, 'to be', this.first);
expect(this.first.root, 'to be', true);
expect(this.second.root, 'to be', false);
});

it('only one root property is set', function() {
var emptyTitleSuite = Suite.create(this.second, '');
expect(emptyTitleSuite.parent, 'to be', this.second);
expect(emptyTitleSuite.root, 'to be', false);
expect(this.second.root, 'to be', false);
});
});

describe('.addSuite()', function() {
beforeEach(function() {
this.first = new Suite('First suite');
Expand Down Expand Up @@ -390,8 +411,8 @@ describe('Suite', function() {
describe('when there is a parent', function() {
describe('the parent is the root suite', function() {
it('returns the suite title', function() {
var parentSuite = new Suite('', {}, true);
parentSuite.addSuite(this.suite);
var rootSuite = new Suite('', {}, true);
rootSuite.addSuite(this.suite);
expect(this.suite.titlePath(), 'to equal', ['A Suite']);
});
});
Expand Down Expand Up @@ -493,16 +514,6 @@ describe('Suite', function() {
new Suite('Bdd suite', 'root');
}, 'not to throw');
});

it('should be root suite', function() {
var rootSuite = new Suite('', {}, true);
expect(rootSuite.root, 'to be', true);
});

it('should not be root suite', function() {
var suite = new Suite('');
expect(suite.root, 'to be', false);
});
});

describe('timeout()', function() {
Expand Down

0 comments on commit dc65b3d

Please sign in to comment.