unbreakable
v1.0.1
Published
A JavaScript Promise implementation with fully encapsulated state.
Downloads
5
Readme
Unbreakable.js
Unbreakable is a JavaScript Promise library that implements the JavaScript 2015 (ES6) Promises API and conforms to the Promises/A+ specification. It differentiates itself from other promise implementations by fully-encapsulating the state of promise objects.
The other promise implementations I looked at allow you to do something like this:
var promise = new Promise(function(resolve, reject) {
// ...
});
promise._state = 'resolved';
promise._resolveValue = 'foo';
promise.then(function(value) {
console.log(value); // foo
});
While I realize most everyone knows better than to do this, I wanted to create a promise implementation that makes it impossible for anyone to improperly mess with the state of a promise object. Thus, an Unbreakable promise's state is inaccessible to the outside world and can only be modified via the callbacks provided to its constructor argument as allowed by the promises spec.
Usage
Installation
npm install --save unbreakable
Loading
If you're working on an ES6 project, you can import the ES6 source file directly:
import Promise from 'unbreakable/lib/Unbreakable';
If you're working on a non-ES6 project, you can load Unbreakable as a
transpiled UMD module from the dist/
directory.
API
Refer to MDN's Guide to the ES6 Promise API, as this is the API that Unbreakable implements.
Development
If you wish to contribute to the development of Unbreakable, here are the things to know.
Running Tests
Unbreakable's tests are written with tape.
npm test
Running the Promises/A+ Spec
npm run spec
Building Tests for the Browser
npm run build_tests
Then open browser-tests.html
in your browser.
Building Distribution File
npm run build
License
MIT