Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/alfonso-presa/testability.js
Independent browser testability state provider
https://github.com/alfonso-presa/testability.js
Last synced: 2 months ago
JSON representation
Independent browser testability state provider
- Host: GitHub
- URL: https://github.com/alfonso-presa/testability.js
- Owner: alfonso-presa
- License: mit
- Created: 2015-06-13T10:50:50.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2016-10-11T18:14:54.000Z (about 8 years ago)
- Last Synced: 2024-10-18T02:04:47.281Z (3 months ago)
- Language: JavaScript
- Homepage: https://github.com/alfonso-presa/testability.js
- Size: 106 KB
- Stars: 7
- Watchers: 5
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# testability.js
[![Build Status](https://secure.travis-ci.org/alfonso-presa/testability.js.png?branch=master)](http://travis-ci.org/alfonso-presa/testability.js)
Independent browser testability state provider
## Installation
Using bower:
```
$ bower install --save-dev testability.js
```Using npm:
```
$ npm install --save-dev testability.js
```## Usage
The purpose of this library is to enable an independent way for frameworks to notify that the current context state is not completed and as such testing frameworks should wait before continuing their testing flow. It is currently meant for the front end
Currently only an implementation is provided but in the future this should be an spec an a reference implementation so that frameworks could provide their own implementation and not depend on this one.
## Documentation
A global object called testability is provided. This object provides a way for runtime frameworks to keep track of their work in progress tasks, and for testing frameworks to be notified when all of this tasks end.
## API
Before continuing after triggering an action that could affect the state of the application being tested, a testing framework should:
```js
testability.when.ready(function () {
//keep on
});
```When starting an asynchronous tasks the runtime framework, library or application should:
```js
testability.wait.for(myPromise);
```Or it can also do this:
```js
var task = testability.wait.start();
//....
//Do some async stuff here
//....
task.end();
```## WIP
Theres two projects in progress:
- [protractor-testability-plugin](https://github.com/alfonso-presa/protractor-testability-plugin): provides an "protractor adapter" so that frameworks diferent from angular could use testability.js spec to be tested with protractor.
- Another (not yet public) to provide an "angular adapter" to enable angular testing with testing frameworks following testability.js spec.## License
MIT