unbreakable

1.0.1 • Public • Published

Unbreakable.js

Travis CI Status

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

Package Sidebar

Install

npm i unbreakable

Weekly Downloads

0

Version

1.0.1

License

MIT

Last publish

Collaborators

  • whastings