Skip to content

xaethos/jasmine-let

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

17 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

jasmine-let

Lazy variable evaluation for Jasmine specs, inspired by Rspec's let.

Installation

$ component install xaethos/jasmine-let

Example

Get a reference to the jasmine let function. As a Component:

var lazy = require('jasmine-let')(
  jasmine, // A reference to jasmine
  window   // The object where the variables should be attached
);

Or if you simply link jasmine-let.js:

var lazy = jasmineLet(jasmine, window);

That's it! Use it in your specs.

describe("A lazily evaluated variable", function () {

  lazy("fooSquare", function () { return foo * foo; });
  lazy("foo", 9);
  lazy("boom", function () { throw "better not call this"; });

  it("only gets evaluated when referenced", function () {
    expect(fooSquare).toEqual(81);
  });

  describe("in a nested describe block", function () {

    lazy("boom", function () { return "bomb defused"; });

    it("overrides definitions in outter blocks", function () {
      expect(function(){ boom; }).not.toThrow();
    });

  });
});

When called with the evaluateBefore: true option, it will evaluate the declaration before the spec (i.e. it behaves like RSpec's let!). It is easiest to use this be creating a wrapper method.

var eager = function (name, declaration) {
  lazy(name, declaration, { evaluateBefore: true });
};

describe("evaluateBefore option", function () {
  var evaluated = false;

  eager('foo', function () { evaluated = true; });

  it("evaluates a definition before the specs (default: false)", function () {
    expect(evaluated).toBeTruthy();
  });
});

License

MIT. See LICENSE file.

About

Lazy variable evaluation for Jasmine specs

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published