Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/otbe/emock
smart mocks for expect
https://github.com/otbe/emock
Last synced: about 2 months ago
JSON representation
smart mocks for expect
- Host: GitHub
- URL: https://github.com/otbe/emock
- Owner: otbe
- License: mit
- Created: 2016-05-15T15:22:06.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2017-08-02T18:00:27.000Z (over 7 years ago)
- Last Synced: 2024-11-19T16:11:45.581Z (about 2 months ago)
- Language: TypeScript
- Homepage:
- Size: 116 KB
- Stars: 3
- Watchers: 4
- Forks: 2
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# emock
[![Build Status](https://travis-ci.org/otbe/emock.svg?branch=master)](https://travis-ci.org/otbe/emock)*emock* automatically generates mocks from your classes. The entire public API will be mocked. It is especially designed
to use in conjunction with ES6 classes (but not exclusive). Internally it uses [expect](https://github.com/mjackson/expect) spies.
It has full TypeScript support and was developed for it!## Install
```npm i emock --save-dev```
## Usage
It is as simple as:```javascript
import { Mock, expectExtensions } from 'emock';
import expect, { extend } from 'expect';extend(expectExtensions);
class MyService {
echo (s: string): string {
return s;
}
}describe('Usage', () => {
it('should show me usage', () => {
let m: Mock = Mock.of(MyService);let service: MyService = m.mock;
console.log(service.echo('name')); // -> undefined
// lets add some spy logic
m.spyOn(x => x.echo('Foo')).andReturn('Bar'); // note: x is from type MyService so will get full code completion! :)console.log(service.echo('name')); // -> Bar
// Was echo called?
expect(service.echo).toHaveBeenCalled();// Was echo called with 'name'?
expect(service.echo).toHaveBeenCalledWith('name');// Why I have added 'Foo' to the spyOn call? Because we could do the following:
(expect(service.echo)).toHaveBeenCalledWithSignature();// the last expect will fail, but why? We have recorded a call signature with m.spyOn(x => x.echo('Foo'))
// That means, if echo is called it should be called with one parameter 'Foo'
// toHaveBeenCalledWithSignature() verifies that for us
});
});
```
See tests for more examples. :)## Matchers
Like I said before ```m.spyOn(x => x.echo('Foo'));``` records a call signature, but you don't have to use explicit values
like in the example above. You can use some matchers from the ```It``` package. For example:```javascript
m.spyOn(x => x.echo(It.isString()));m.mock.echo('test');
(expect(m.mock.echo)).toHaveBeenCalledWithSignature(); // passesm.mock.echo('test2');
(expect(m.mock.echo)).toHaveBeenCalledWithSignature(); // passesm.mock.echo(5);
(expect(m.mock.echo)).toHaveBeenCalledWithSignature(); // fails with 5 is not a string```
## Dependencies
*emock* itself has no dependencies, but some peerDependencies.* [expect](https://github.com/mjackson/expect) (because *emock* relies on it)
* [is-equal](https://www.npmjs.com/package/is-equal) (comes with expect)You will need some polyfills for your environment if there is no support for used features:
* [Reflect API](https://www.npmjs.com/package/reflect-metadata) with metadata support
* ```Symbol``` polyfill (comes with babel-polyfill for example)