1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-06 11:45:33 +01:00

increase test coverage

This commit is contained in:
Matthias Kretschmann 2019-07-14 00:43:09 +02:00
parent 62152681f6
commit 1cdc34f216
Signed by: m
GPG Key ID: 606EEEF3C479A91F
5 changed files with 37 additions and 2 deletions

View File

@ -58,6 +58,7 @@
"@babel/core": "^7.4.5", "@babel/core": "^7.4.5",
"@babel/node": "^7.4.5", "@babel/node": "^7.4.5",
"@babel/preset-env": "^7.4.5", "@babel/preset-env": "^7.4.5",
"@react-mock/localstorage": "^0.1.2",
"@svgr/webpack": "^4.3.0", "@svgr/webpack": "^4.3.0",
"@testing-library/jest-dom": "^4.0.0", "@testing-library/jest-dom": "^4.0.0",
"@testing-library/react": "^8.0.2", "@testing-library/react": "^8.0.2",

View File

@ -38,7 +38,9 @@ describe('ThemeSwitch', () => {
) )
const toggle = container.querySelector('input') const toggle = container.querySelector('input')
const label = container.querySelector('label')
expect(toggle.checked).toBeFalsy() expect(toggle.checked).toBeFalsy()
fireEvent.click(label)
fireEvent.change(toggle, { target: { checked: true } }) fireEvent.change(toggle, { target: { checked: true } })
expect(toggle.checked).toBeTruthy() expect(toggle.checked).toBeTruthy()
}) })

View File

@ -6,7 +6,7 @@ import styles from './Repositories.module.scss'
export default class Repositories extends PureComponent { export default class Repositories extends PureComponent {
static propTypes = { static propTypes = {
repos: PropTypes.array.isRequired repos: PropTypes.array
} }
render() { render() {

View File

@ -8,4 +8,9 @@ describe('Repositories', () => {
const { container } = render(<Repositories repos={repos} />) const { container } = render(<Repositories repos={repos} />)
expect(container.firstChild).toBeInTheDocument() expect(container.firstChild).toBeInTheDocument()
}) })
it('return nothing when no repos are passed', () => {
const { container } = render(<Repositories />)
expect(container.firstChild).not.toBeInTheDocument()
})
}) })

View File

@ -1,6 +1,8 @@
import React from 'react' import React from 'react'
import { render } from '@testing-library/react' import { render, fireEvent } from '@testing-library/react'
import { LocalStorageMock } from '@react-mock/localstorage'
import AppProvider from './AppProvider.jsx' import AppProvider from './AppProvider.jsx'
import { Consumer } from './createContext.jsx'
describe('AppProvider', () => { describe('AppProvider', () => {
it('renders correctly', () => { it('renders correctly', () => {
@ -8,4 +10,29 @@ describe('AppProvider', () => {
expect(container.firstChild.textContent).toBe('Hello') expect(container.firstChild.textContent).toBe('Hello')
}) })
it('renders with dark detected in localStorage', () => {
const { getByTestId } = render(
<LocalStorageMock items={{ dark: 'true' }}>
<AppProvider>
<Consumer>
{state => (
<button data-testid="toggle" onClick={() => state.toggleDark()}>
Toggle
</button>
)}
</Consumer>
</AppProvider>
</LocalStorageMock>
)
fireEvent.click(getByTestId('toggle'))
})
it('renders with light detected in localStorage', () => {
render(
<LocalStorageMock items={{ dark: 'false' }}>
<AppProvider>Hello</AppProvider>
</LocalStorageMock>
)
})
}) })