Abandoned in favor of splitting up the functionality into
- muk-prop - Mock object methods and properties
- muk-require - Mock dependencies
Mock dependencies.
foo.js
var request = require('request');
module.exports = function foo(url) {
// do something with request
};
test.js
var mockedRequest = function(url, options, callback) {
// mock a request here
};
var foo = muk('./foo', {
request: mockedRequest
});
You can also mock modules required with a relative path.
some/where/else/foo.js
var bar = require('./bar');
module.exports = function() {
// do something with bar
};
some/where/else/bar.js
exports.attack = 'sludge attack!';
test.js
var foo = muk('./some/where/else/foo', { './bar': 'hey!!' });
Comes with object method mocking too.
var fs = require('fs');
var muk = require('muk');
muk(fs, 'readFile', function(path, callback) {
process.nextTick(callback.bind(null, null, 'file contents here'));
});
Check if member has been mocked.
muk.isMocked(fs, 'readFile'); // true
Restore all mocked methods after tests.
muk.restore();
fs.readFile(file, function(err, data) {
// will actually read from `file`
});
npm install muk
Tests are written with mocha
npm test
MIT