Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mars/episode-7
A facade for side-effects: write test-friendly, async/await-style, JS code
https://github.com/mars/episode-7
async-programming es2015 generator promises
Last synced: 3 months ago
JSON representation
A facade for side-effects: write test-friendly, async/await-style, JS code
- Host: GitHub
- URL: https://github.com/mars/episode-7
- Owner: mars
- License: mit
- Created: 2016-07-05T03:04:36.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2020-04-13T13:31:14.000Z (almost 5 years ago)
- Last Synced: 2024-10-04T15:53:42.275Z (4 months ago)
- Topics: async-programming, es2015, generator, promises
- Language: JavaScript
- Homepage:
- Size: 33.2 KB
- Stars: 10
- Watchers: 3
- Forks: 0
- Open Issues: 2
-
Metadata Files:
- Readme: README.markdown
- Changelog: CHANGELOG.markdown
- License: LICENSE
Awesome Lists containing this project
README
Episode 7 📺
============
A facade for side-effects: write test-friendly, async/await-style, JS code.[![Build Status](https://travis-ci.org/mars/episode-7.svg?branch=master)](https://travis-ci.org/mars/episode-7)
[![npm Module](https://img.shields.io/npm/v/episode-7.svg)](https://www.npmjs.com/package/episode-7)Care about unit testing around [side-effects](https://en.wikipedia.org/wiki/Side_effect_(computer_science))? You may fall in love with Episode 7.
### Episode 7 is a simpler way
* spy on, intercept, & fake async function calls
* avoid brittle HTTP mocks
* confidently handle async errors### A tiny library 🐿
* no production npm dependencies
* <100-lines-of-code (without comments)### Functional in nature 🌲
Inspired by the test-friendly [generator](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Generator) architecture of [`redux-saga`](https://github.com/yelouafi/redux-saga) and the pure side-effects of [Elm](http://elm-lang.org).
Requires
--------[ES6/Generator](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Generator) support.
* Known to work in [Node.js](https://nodejs.org) 6.2
* Should work in any ES6-compliant JavaScript environmentInstall
-------```bash
npm install episode-7 --save
```Changes
-------See: [CHANGELOG](CHANGELOG.markdown)
Usage
-----```javascript
const Episode7 = require('episode-7');
const fetch = require('node-fetch');// Compose an Episode 7 Generator for an async call sequence.
//
function* findFirstMovie(searchTerm) {// Wrap side-effects with Episode 7's `call`
//
let results = yield Episode7.call(
fetchJson,
`http://www.omdbapi.com/?s=${encodeURIComponent(searchTerm)}`
);// Do something programmatic with the result.
//
let firstResultId = results.Search[0].imdbID;
// Use that transformed value to make the next call.
//
let movie = yield Episode7.call(
fetchJson,
`http://www.omdbapi.com/?i=${encodeURIComponent(firstResultId)}`
);return movie;
}// Side-effect function,
// a barebones helper to fetch & decode JSON.
//
function fetchJson(url) {
return fetch(url).then( response => response.json() );
}// Run the generator with Episode 7, returning a promise.
//
Episode7.run(findFirstMovie, 'Episode 7')
.then( movie => console.log(movie.Title) )
.catch( error => console.error(error) )
```### Smooth running tips 🚝
#### Handle errors
[`catch`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/catch) after `Episode7.run` to handle errors from the async flow (log|exit|retry).
Avoid catching within side-effect functions. Allow their errors to bubble up.
#### Name generator functions
Declare generator functions as [named function expressions](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/function); this makes stacktraces & error messages more meaningful.
Background
----------
I created this module to make it easy to code & test sequences of web service API requests interleaved with programmatic logic. I'm pulling the essence of [`redux-saga`](https://github.com/yelouafi/redux-saga) into the smallest, plainest surface area conceivable.