0.2.3 • Published 4 years ago
jest-ld-mock v0.2.3
jest-launchdarkly-mock
Installation
yarn -D jest-launchdarkly-mockor
npm install jest-launchdarkly-mock --save-devThen in jest.config.js add jest-launchdarkly-mock to setupFiles:
// jest.config.js
module.exports = {
setupFiles: ['jest-launchdarkly-mock'],
}Usage
Use the only 3 apis for test cases:
mockFlags(flags: LDFlagSet, Options?: mockFlagsOptions): mock flags at the start of each test case.
Options
| name | type | default | description |
|---|---|---|---|
| skipFormatting(optional) | boolean | false | If true, flags will not be formatted to camelCase or kebab-case |
ldClientMock: a jest mock of the ldClient. All methods of this object are jest mocks.resetLDMocks: resets both mockFlags and ldClientMock.
Example
import { mockFlags, ldClientMock, resetLDMocks } from 'jest-launchdarkly-mock'
describe('button', () => {
beforeEach(() => {
// reset before each test case
resetLDMocks()
})
test('flag on', () => {
// arrange: You can use kebab-case or camelCase keys
mockFlags({ devTestFlag: true })
// act
const { getByTestId } = render(<Button />)
// assert
expect(getByTestId('test-button')).toBeTruthy()
})
test('identify', () => {
// arrange
mockFlags({ 'dev-test-flag': true })
// act
const { getByTestId } = render(<Button />)
fireEvent.click(getByTestId('test-button'))
// assert: identify gets called
expect(ldClientMock.identify).toBeCalledWith({ key: 'aa0ceb' })
})
})