Security News
Fluent Assertions Faces Backlash After Abandoning Open Source Licensing
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
simple-mock
Advanced tools
Super simple mocks, stubs, and spies with 1-step sandbox restore.
npm install simple-mock
You can mock any function or value on an object and easily restore it.
Examples
simple.mock(obj, 'example', 'value'); // Replace with this value
simple.mock(obj, 'example', function() {}); // Replace with this function
simple.mock(obj, 'example') // Spy on underlying method *or* stub
simple.mock(obj, 'example').callbackWith(null, 'etc'); // Stub
simple.mock(obj, 'example').returnWith('etc'); // Stub
simple.mock(obj, 'example').throwWith(new Error()); // Stub
Then, to make sure all objects are back to the state the were in before your mocks:
simple.restore(); // Ideally called in an afterEach() block
callbackWith
, returnWith
and throwWith
can be chained for queued behaviour, e.g.
simple.mock(Something.prototype, 'example')
.callbackWith(null, 'etc')
.callbackWith(new Error());
callbackWith
, returnWith
and throwWith
configurations are stored on a simple array fn.actions
You define your expectations with your own choice of assertion library.
assert(fn.called);
assert.equals(fn.callCount, 3);
assert.equals(fn.lastCall.args[0], error); // First parameter of the last call
assert.equals(fn.calls[0].returned, 'etc');
assert.equals(fn.calls[1].threw, error);
If you need to create a standalone stub (stubs are also spies):
simple.stub().callbackWith(null, 'etc');
simple.stub().returnWith('etc');
simple.stub().throwWith(new Error());
Or spy on a standalone function:
var fn = simple.spy(function(){});
assert.equals(fn.callCount, 0);
assert.equals(fn.calls, []);
FAQs
Super simple stubs and spies with 1-step sandbox restore
The npm package simple-mock receives a total of 9,364 weekly downloads. As such, simple-mock popularity was classified as popular.
We found that simple-mock demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Fluent Assertions is facing backlash after dropping the Apache license for a commercial model, leaving users blindsided and questioning contributor rights.
Research
Security News
Socket researchers uncover the risks of a malicious Python package targeting Discord developers.
Security News
The UK is proposing a bold ban on ransomware payments by public entities to disrupt cybercrime, protect critical services, and lead global cybersecurity efforts.