Skip to content

Instantly share code, notes, and snippets.

View stipsan's full-sized avatar

Cody Olsen stipsan

View GitHub Profile
@stipsan
stipsan / Input-test.jsx
Last active June 16, 2017 09:49
Testing with Jest: Tip #10
import renderer from 'react-test-renderer'
import Input from '../Input'
it('should render correctly', () => {
const component = renderer.create(<Input />)
expect(component.toJSON()).toMatchSnapshot()
// getInstance is returning the `this` object you have in your component
// meaning anything accessible on `this` inside your component
// can be accessed on getInstance, including props!
@stipsan
stipsan / package.json
Last active August 29, 2018 16:52
Testing with Jest: Tip #9
{
"jest": {
"setupFiles": [
"<rootDir>/test-setup.js"
]
}
}
@stipsan
stipsan / package.json
Last active August 10, 2018 17:43
Testing with Jest: Tip #8
{
"jest": {
"setupFiles": [
"<rootDir>/test-setup.js"
]
}
}
@stipsan
stipsan / App-test.jsx
Last active June 16, 2017 09:44
Testing with Jest: Tip #7
import renderer from 'react-test-renderer'
import App from '../App'
// Generated snapshot is exactly like the previous example
// while it's possible to override the default mock
// by using the same jest.mock command as before
// if this test need a different behavior than the
// glboal mock.
it('should render correctly', () => {
@stipsan
stipsan / App-test.jsx
Last active June 16, 2017 09:44
Testing with Jest: Tip #6
import renderer from 'react-test-renderer'
import App from '../App'
jest.mock('react-router-dom', () => ({
Link: 'Link',
Route: ({ children, ...props }) =>
typeof children === 'function'
? children({ match: path === '/somewhere' })
: createElement('Route', props)
}))
@stipsan
stipsan / Select-test.jsx
Last active June 16, 2017 09:36
Testing with Jest: Tip #3
import renderer from 'react-test-renderer'
import Select from '../Select'
jest.mock('react-select', () => {
const { createElement } = require('react')
// Note that since 'react-select' is mocked we have to use
// require.requireActual, even inside the factory function that mocks it!
// Just watch the movie Inception and skip to the Dream within a Dream and you'll get it
const ReactSelect = require.requireActual('react-select')
@stipsan
stipsan / Sidebar-test.jsx
Last active December 19, 2023 12:43
Testing with Jest: Tip #5
import renderer from 'react-test-renderer'
import Sidebar from '../Sidebar'
jest.mock('react-router-dom', () => ({
Link: 'Link',
Route: ({ children, path }) => children({ match: path === '/somewhere' })
}))
it('should render correctly', () => {
const component = renderer.create(<Sidebar />)
@stipsan
stipsan / Header-test.jsx
Last active June 16, 2017 09:40
Testing with Jest: Tip #4
import renderer from 'react-test-renderer'
import Header from '../Header'
import store from '../store'
jest.mock('react-redux-loading-bar', () => {
const ReactReduxLoadingBar = require.requireActual('react-redux-loading-bar')
return {
// Spread out the original module
...ReactReduxLoadingBar,
@stipsan
stipsan / Sidebar-test.jsx
Last active June 16, 2017 09:35
Testing with Jest: Tip #2
import renderer from 'react-test-renderer'
import Sidebar from '../Sidebar'
jest.mock('react-router-dom', () => ({ Link: 'Link' }))
it('should render correctly', () => {
const component = renderer.create(<Sidebar />)
expect(component.toJSON()).toMatchSnapshot()
})
@stipsan
stipsan / Sidebar-test.jsx
Last active June 16, 2017 09:34
Testing with Jest: Tip #1
import renderer from 'react-test-renderer'
import Sidebar from '../Sidebar'
jest.mock('react-router-dom/Link', () => 'Link')
it('should render correctly', () => {
const component = renderer.create(<Sidebar />)
expect(component.toJSON()).toMatchSnapshot()
})