Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/Legitcode/tests
Chainable, easy to read, React testing library
https://github.com/Legitcode/tests
Last synced: 3 months ago
JSON representation
Chainable, easy to read, React testing library
- Host: GitHub
- URL: https://github.com/Legitcode/tests
- Owner: Legitcode
- Created: 2015-09-10T22:05:18.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2016-04-29T14:54:10.000Z (over 8 years ago)
- Last Synced: 2024-10-01T16:20:34.031Z (4 months ago)
- Language: JavaScript
- Homepage:
- Size: 143 KB
- Stars: 248
- Watchers: 12
- Forks: 7
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- awesome-react-components-all - legit-tests - Chainable, easy to read, React testing library. (Uncategorized / Uncategorized)
- awesome-list - legit-tests - Chainable, easy to read, React testing library. (Dev Tools / Test)
- awesome-react-components - legit-tests - Chainable, easy to read, React testing library. (Dev Tools / Test)
README
##Legit Tests
This is a super friendly testing library for React, inspired by express middleware, it's easily extendable. Why did I make this when you can use [React's Test Utils](https://facebook.github.io/react/docs/test-utils.html)? Because who likes typing out `scryRenderedDOMComponentsWithTag` and the other method names on there. Not only that, but setting up the render process is also a hassle.
###Install
`npm install legit-tests --save`
##Example
~~~js
import Test from 'legit-tests'
//or
import Test from 'legit-tests/no-dom' //don't include jsdomimport { expect } from 'chai'
import sinon from 'sinon'
import TestComponent from './TestComponent'let spy = sinon.spy()
//Calling a prop
Test()
.find('button')
.simulate({method: 'click', element: 'button'})
.test(() => {
expect(spy.called).to.be.true
})//finding an element
Test()
.find('.box')
.elements('.box', (box) => {
expect(box.props.children).to.be.equal('found me!')
})
~~~##Middleware
[Current list of Middleware](https://github.com/Legitcode/tests/wiki/Bundled-Middleware)
You can write middleware to do anything you repeatedly use. You can pass `.use` a function, along with an object that it will take in. Each function will be injected with the current instance which includes:
- `component` - the actual component itself
- `instance` - the rendered component instance
- `helpers` - an array you can add on to with data for the end function**Example**:
- See `mixin` below, this syntax may soon be deprecated
This is the setState function used above.
~~~jsTest()
.use(SetState, {})...
export default function setState(state){
this.instance.setState(state)
}
~~~##test
The `.test` function will be given the component instance and the helpers array. You can use a regular function to reference `this` or an arrow function:
~~~js
.test(({helpers, instance}) => { ... })
.test(function() {
//this.instance, this.helpers
})
~~~##element
Use `.element` if you're just testing an element you found with the `.find` method. The syntax is a little smaller:
~~~js
Test()
.find('.box')
.element(box => {
expect(box.props.children).to.be.equal('found me!')
})
//or specify the element.find('.box')
.find('div')
.element('.box', box => {
expect(box.props.children).to.be.equal('found me!')
})~~~
##mixin
Use `.mixin` if you want to add new middleware as methods to `Test`. This gives a more natural way of using middleware:
~~~js
// In this example, CustomFind middleware was added to Test by mixin
// and used if as it was a method on Test itself.Test()
.mixin({
customFind: CustomFind
})
.customFind('cells', 'table td')
.element('cells', cells => {
expect(cells.length).to.be.equal(10)
})~~~
##DOM rendering
__Shallow__ -- uses React shallow rendering (no DOM)
~~~js
Test(, {shallow: true})
.find('button')
.simulate({method: 'click', element: 'button'})
.test(() => {
expect(spy.called).to.be.true
})
~~~__Normal__ -- React render into document fragment
~~~js
Test()
.find('button')
.simulate({method: 'click', element: 'button'})
.test(() => {
expect(spy.called).to.be.true
})
~~~__fullDOM__ -- ReactDOM render into document.body.div of jsdom
~~~js
Test(, {fullDOM: true})
.test(function() {
expect(global.window.document.querySelector('section'))
.to.be.okay
})
.clean() // restores the document.body to empty
~~~You can see more examples in the tests directory.
##Testing Alt Stores
You can now test [Alt](http://alt.js.org/) stores using the same API.
~~~js
import TestStore from 'legit-tests/alt/store'TestStore(MyStore, MyActions)
.setInitialState({ todos: todos })
.addTodo({ title: "Get Beer", complete: false })
.test(({ state }) => {
expect(state.todos).to.eql(expected);
})
~~~You can see the [full documentation on the Wiki](https://github.com/Legitcode/tests/wiki/Alt-Stores)