diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 0ac1d136c..c39a39590 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -91,7 +91,7 @@ Tagging tests uses the `#` sigil followed by a kebab case name. Tagging happens ### Roles -Roles are a special type of [tag](#tagging). You invoke them the same way, using the `--tag` option, but they must map to login details contained in `config/`. You tag tests using the `roles` helper. The `roles` helper binds the tests inside it for each role in the string. +Roles are a special type of [tag](#tagging). You invoke them the same way, using the `--tag` option, but they must map to login details contained in `config/`. You tag tests using the `roles` helper. The `roles` helper binds the tests inside it for each role in the string, array of string or first `n` arguments. If you have a scenario like @@ -103,6 +103,16 @@ roles('#my-role-1 #my-role-2', function() { }); ``` +or + +```js +roles('#my-role-1', '#my-role-2', function() { + it('my test', function() { + // ... + }); +}); +``` + You would get two tests ``` diff --git a/packages/mocha/src/role.js b/packages/mocha/src/role.js index ab4a61939..a254dad24 100644 --- a/packages/mocha/src/role.js +++ b/packages/mocha/src/role.js @@ -7,16 +7,23 @@ const { wrap } = require('./mocha'); function roles(getRole, getFilePathTitle) { return mocha => { - return function roles(tags, callback) { - // must be instanced and not inline - // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp/exec#Finding_successive_matches - let regex = /(?:^| )#([^ ]+)/g; + return function roles(...args) { + let callback = args.pop(); + + let roles = []; + if (args.length > 1) { // roles as multiple arguments + roles = args; + } else if (typeof args[0] === 'string' || arguments[0] instanceof String) { // roles as concatenated string + // must be instanced and not inline + // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/RegExp/exec#Finding_successive_matches + let regex = /(?:^| )#([^ ]+)/g; + let matches = args[0].matchAll(regex); + roles = [...matches].map(i => i[1]); + } function loopRoles() { // eslint-disable-next-line no-cond-assign - for (let matches; matches = regex.exec(tags);) { - let role = matches[1]; - + for (let role of roles) { mocha.describe(`#${role}`, function() { global.before(function() { this.role = getRole(role); diff --git a/packages/mocha/test/acceptance/index-test.js b/packages/mocha/test/acceptance/index-test.js index 65c937c73..8c44aafca 100644 --- a/packages/mocha/test/acceptance/index-test.js +++ b/packages/mocha/test/acceptance/index-test.js @@ -108,7 +108,7 @@ describe(function() { it('works', async function() { let stats = await this.runTests(); - expect(stats.passes).to.equal(3); + expect(stats.passes).to.equal(6); }); it('works with a role', async function() { @@ -124,7 +124,7 @@ describe(function() { tag: ['!role1'], }); - expect(stats.passes).to.equal(2); + expect(stats.passes).to.equal(5); }); }); diff --git a/packages/mocha/test/fixtures/role-test.js b/packages/mocha/test/fixtures/role-test.js index 5ceffc364..041aae94d 100644 --- a/packages/mocha/test/fixtures/role-test.js +++ b/packages/mocha/test/fixtures/role-test.js @@ -12,15 +12,15 @@ describe('role', function() { }); }); - roles('#role2', function() { + roles('#role2 #role3', function() { it('works', function() { - assert.strictEqual(this.role, 'role2'); + assert.ok(this.role.match(/role[2|3]/)); }); }); - roles('#role3', function() { + roles('#role4', '#role5', '#role6', function() { it('works', function() { - assert.strictEqual(this.role, 'role3'); + assert.ok(this.role.match(/role[4|5|6]/)); }); }); });