bdd-wrappers
Version:
BDD wrappers for jasmine and mocha describe/it to help writing tests in GIVEN WHEN THEN AND fashion
124 lines (95 loc) • 2.42 kB
Markdown
bdd-wrappers
=============
BDD wrappers for jasmine and mocha describe/it to help writing tests in GIVEN WHEN THEN AND fashion so you can write:
```js
GIVEN("a gremlin", function () {
WHEN("I feed it", function () {
beforeEach(function () {
gremlin.feed();
});
THEN("is happy", function () {
expect(gremlin.happy).to.be.true;
});
AND("I give it water", function () {
beforeEach(function () {
gremlin.water();
});
THEN("they are all happy", function () {
expect(gremlin[0].happy).to.be.true;
expect(gremlin[1].happy).to.be.true;
expect(gremlin[2].happy).to.be.true;
expect(gremlin[3].happy).to.be.true;
});
});
WHEN("it's past midnight", function () {
beforeEach(function () {
time.set('0000');
gremlin.feed();
});
THEN("it's not cute anymore", function () {
expect(gremlin.cute).to.be.false;
});
});
});
});
```
Instead of:
```js
describe("GIVEN a gremlin", function () {
describe("WHEN I feed it", function () {
beforeEach(function () {
gremlin.feed();
});
it("THEN is happy", function () {
expect(gremlin.happy).to.be.true;
});
describe("AND I give it water", function () {
beforeEach(function () {
gremlin.water();
});
it("THEN they are all happy", function () {
expect(gremlin[0].happy).to.be.true;
expect(gremlin[1].happy).to.be.true;
expect(gremlin[2].happy).to.be.true;
expect(gremlin[3].happy).to.be.true;
});
});
describe("WHEN it's past midnight", function () {
beforeEach(function () {
time.set('0000');
gremlin.feed();
});
it("THEN it's not cute anymore", function () {
expect(gremlin.cute).to.be.false;
});
});
});
});
```
When a test fails, the trace will correctly output GIVEN a gremlin WHEN I feed it THEN is happy.
Installation
============
```bash
npm install bdd-wrappers
```
How to use
==========
This will add the GIVEN, WHEN, AND, THEN functions to the global object
```js
require("bdd-wrappers");
GIVEN(...);
```
You can also define your own wrappers. The first parameter is a string and will prefix the string describing the test.
```js
var wrap = require("bdd-wrappers").wrap;
// A wrapper for it(...);
GLOBAL.SHOULD = wrap("SHOULD ", it);
// So:
SHOULD("do something", func);
// will ouput: SHOULD so something
// A wrapper for describe(...);
GLOBAL.OR = wrap("OR ", describe);
```
LICENSE
=======
MIT