Skip to content

Latest commit

 

History

History
97 lines (69 loc) · 2.36 KB

README.md

File metadata and controls

97 lines (69 loc) · 2.36 KB

ensure

ensure is just a simple way to test in node.js

installation

  1. install npm
  2. npm install ensure

usage

  var ensure = require('ensure')
    , assert = require('assert')
    , tests = exports
    ;

  tests.foo = function (callback) {
    callback(true);
  };

  tests.foo_ok = function (t) {
    assert.ok(t);
  };

  ensure('foo', tests, module);

run it:

  node foo.js

an extra parameter is available to allow you to define only some tests from a specific file. you can do this by providing a comma separated list of tests you want to run, e.g. ensure('foo',tests,module,'foo,bar');. you can use this in combination with process.argv to choose what tests to run from the shell:

  // assuming node foo.js foo,bar
  ensure('foo',tests,module,process.argv[2]);

you can also set ensure to use a different test engine. for now we have tap and vows available with vows by default. here's an example using tap

  var ensure = require('ensure').use('tap')
    , tests = exports
    ;

  tests.tap    = function (cb) { cb('foo'); };
  tests.tap_ok = function (value)  {
    var t = this.t; // get the assertions from tap engine
    t.equal(value,'foo','foo test worked'); 
  };

  ensure(__filename,tests,module,process.argv[2]);

to run test tap you can do:

  node test/tap.js tap

tap is the test name and is optional (by default all tests run).

contribute

everyone is welcome to contribute. patches, bugfixes, new features

  1. create an issue on github so the community can comment on your idea
  2. fork nano in github
  3. create a new branch git checkout -b my_branch
  4. create tests for the changes you made
  5. make sure you pass both existing and newly inserted tests
  6. commit your changes
  7. push to your branch git push origin my_branch
  8. create an pull request

tests

  1. install the packages referred as dev dependencies in package.json
  2. browse to test/ and ./run.

always make sure all the tests pass before sending in your pull request!

meta

(oO)--',- in caos