Skip to content

Commit

Permalink
test: adds tests for text widget
Browse files Browse the repository at this point in the history
  • Loading branch information
geotrev committed Oct 10, 2022
1 parent 569160c commit aa04fad
Showing 1 changed file with 96 additions and 0 deletions.
96 changes: 96 additions & 0 deletions packages/netlify-cms-widget-text/src/__tests__/text.spec.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,96 @@
import React from 'react';
import { render, fireEvent } from '@testing-library/react';

import { NetlifyCmsWidgetText } from '../';

const TextControl = NetlifyCmsWidgetText.controlComponent;

class TextController extends React.Component {
state = {
value: this.props.defaultValue,
};

handleOnChange = jest.fn(value => {
this.setState({ value });
});

render() {
return this.props.children({
value: this.state.value,
handleOnChange: this.handleOnChange,
});
}
}

function setup({ defaultValue } = {}) {
let renderArgs;
const setActiveSpy = jest.fn();
const setInactiveSpy = jest.fn();

const helpers = render(
<TextController defaultValue={defaultValue}>
{({ value, handleOnChange }) => {
renderArgs = { value, onChangeSpy: handleOnChange };
return (
<TextControl
value={value}
onChange={handleOnChange}
forID="test-string"
classNameWrapper="test-classname"
setActiveStyle={setActiveSpy}
setInactiveStyle={setInactiveSpy}
/>
);
}}
</TextController>,
);

const textarea = helpers.container.querySelector('textarea');

return {
...helpers,
...renderArgs,
setActiveSpy,
setInactiveSpy,
textarea,
};
}

describe('String widget', () => {
it('calls setActiveStyle when textarea focused', () => {
const { textarea, setActiveSpy } = setup();

fireEvent.focus(textarea);

expect(setActiveSpy).toBeCalledTimes(1);
});

it('calls setInactiveSpy when textarea blurred', () => {
const { textarea, setInactiveSpy } = setup();

fireEvent.focus(textarea);
fireEvent.blur(textarea);

expect(setInactiveSpy).toBeCalledTimes(1);
});

it('renders with default value', () => {
const testValue = 'bar';
const { textarea } = setup({ defaultValue: testValue });
expect(textarea.value).toEqual(testValue);
});

it('calls onChange when textarea changes', () => {
jest.useFakeTimers();
const testValue = 'foo';
const { textarea, onChangeSpy } = setup();

fireEvent.focus(textarea);
fireEvent.change(textarea, { target: { value: testValue } });

jest.runAllTimers();

expect(onChangeSpy).toBeCalledTimes(1);
expect(onChangeSpy).toBeCalledWith(testValue);
});
});

0 comments on commit aa04fad

Please sign in to comment.