2020-11-26 03:27:18 -06:00
|
|
|
import { mount } from 'enzyme';
|
2020-11-13 07:41:20 -06:00
|
|
|
import * as React from 'react';
|
|
|
|
import AnnotateArea from '../src/renderer/components/annotate-area';
|
|
|
|
import { Tool } from '../src/renderer/components/snipping-tool';
|
2020-12-10 06:18:23 -06:00
|
|
|
import { ipcRenderer } from './__mocks__/electron';
|
2020-11-13 07:41:20 -06:00
|
|
|
|
|
|
|
const defaultProps = {
|
|
|
|
paths: [],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
2020-11-26 03:27:18 -06:00
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
2020-11-13 07:41:20 -06:00
|
|
|
chosenTool: Tool.pen,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
|
|
|
|
|
|
|
afterEach(() => {
|
|
|
|
jest.clearAllMocks();
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('<AnnotateArea/>', () => {
|
|
|
|
it('should render correctly', () => {
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...defaultProps} />);
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(wrapper).toMatchSnapshot();
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call onChange when drawn on annotate area', () => {
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...defaultProps} />);
|
|
|
|
const area = wrapper.find('[data-testid="annotate-area"]');
|
|
|
|
area.simulate('mousedown', { pageX: 2, pageY: 49 });
|
|
|
|
area.simulate('mouseup');
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(defaultProps.onChange).toHaveBeenCalledTimes(1);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call onChange with correct pen props if drawn drawn on annotate area with pen', () => {
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...defaultProps} />);
|
|
|
|
const area = wrapper.find('[data-testid="annotate-area"]');
|
|
|
|
area.simulate('mousedown', { pageX: 2, pageY: 49 });
|
|
|
|
area.simulate('mouseup');
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(defaultProps.onChange).toHaveBeenCalledWith([{
|
|
|
|
color: 'rgba(38, 196, 58, 1)',
|
|
|
|
key: 'path0',
|
2020-11-26 03:27:18 -06:00
|
|
|
points: [{ x: 0, y: 0 }],
|
2020-11-13 07:41:20 -06:00
|
|
|
shouldShow: true,
|
|
|
|
strokeWidth: 5,
|
|
|
|
}]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should call onChange with correct highlight props if drawn drawn on annotate area with highlight', () => {
|
|
|
|
const highlightProps = {
|
|
|
|
paths: [],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
2020-11-26 03:27:18 -06:00
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
2020-11-13 07:41:20 -06:00
|
|
|
chosenTool: Tool.highlight,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...highlightProps} />);
|
|
|
|
const area = wrapper.find('[data-testid="annotate-area"]');
|
|
|
|
area.simulate('mousedown', { pageX: 2, pageY: 49 });
|
|
|
|
area.simulate('mouseup');
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(highlightProps.onChange).toHaveBeenCalledWith([{
|
|
|
|
color: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
key: 'path0',
|
|
|
|
points: [{ x: 0, y: 0 }],
|
|
|
|
shouldShow: true,
|
|
|
|
strokeWidth: 28,
|
|
|
|
}]);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should render path if path is provided in props', () => {
|
|
|
|
const pathProps = {
|
|
|
|
paths: [{
|
|
|
|
points: [{ x: 0, y: 0 }],
|
|
|
|
shouldShow: true,
|
|
|
|
strokeWidth: 5,
|
|
|
|
color: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
key: 'path0',
|
|
|
|
}],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
2020-11-26 03:27:18 -06:00
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
2020-11-13 07:41:20 -06:00
|
|
|
chosenTool: Tool.highlight,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...pathProps} />);
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(wrapper.find('[data-testid="path0"]').exists()).toEqual(true);
|
|
|
|
});
|
|
|
|
|
|
|
|
it('should not render any path if no path is provided in props', () => {
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...defaultProps} />);
|
2020-11-13 07:41:20 -06:00
|
|
|
expect(wrapper.find('[data-testid="path0"]').exists()).toEqual(false);
|
|
|
|
});
|
2020-11-19 02:17:39 -06:00
|
|
|
|
|
|
|
it('should call onChange with hidden path if clicked on path with tool eraser', () => {
|
|
|
|
const pathProps = {
|
|
|
|
paths: [{
|
|
|
|
points: [{ x: 0, y: 0 }],
|
|
|
|
shouldShow: true,
|
|
|
|
strokeWidth: 5,
|
|
|
|
color: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
key: 'path0',
|
|
|
|
}],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
2020-11-26 03:27:18 -06:00
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
2020-11-19 02:17:39 -06:00
|
|
|
chosenTool: Tool.eraser,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
2020-11-26 03:27:18 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...pathProps} />);
|
2020-11-19 02:17:39 -06:00
|
|
|
const path = wrapper.find('[data-testid="path0"]');
|
|
|
|
path.simulate('click');
|
|
|
|
expect(pathProps.onChange).toHaveBeenCalledWith([{
|
|
|
|
color: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
key: 'path0',
|
|
|
|
points: [{ x: 0, y: 0 }],
|
|
|
|
shouldShow: false,
|
|
|
|
strokeWidth: 5,
|
|
|
|
}]);
|
|
|
|
});
|
2020-11-27 10:07:46 -06:00
|
|
|
|
2020-12-03 10:22:06 -06:00
|
|
|
it('should send annotate_erased if clicked on path with tool eraser', () => {
|
2020-12-10 06:18:23 -06:00
|
|
|
const spy = jest.spyOn(ipcRenderer, 'send');
|
2020-12-03 10:22:06 -06:00
|
|
|
const pathProps = {
|
|
|
|
paths: [{
|
|
|
|
points: [{ x: 0, y: 0 }],
|
|
|
|
shouldShow: true,
|
|
|
|
strokeWidth: 5,
|
|
|
|
color: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
key: 'path0',
|
|
|
|
}],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
|
|
|
chosenTool: Tool.eraser,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
|
|
|
const wrapper = mount(<AnnotateArea {...pathProps} />);
|
|
|
|
const path = wrapper.find('[data-testid="path0"]');
|
2020-12-10 06:18:23 -06:00
|
|
|
const expectedValue = { type: 'annotate_erased', element: 'screen_capture_annotate' };
|
2020-12-03 10:22:06 -06:00
|
|
|
path.simulate('click');
|
2020-12-18 07:11:15 -06:00
|
|
|
expect(spy).toBeCalledWith('snippet-analytics-data', expectedValue);
|
2020-12-03 10:22:06 -06:00
|
|
|
});
|
|
|
|
|
|
|
|
it('should send annotate_added_pen event when drawn with pen', () => {
|
2020-12-10 06:18:23 -06:00
|
|
|
const spy = jest.spyOn(ipcRenderer, 'send');
|
|
|
|
const expectedValue = { type: 'annotate_added_pen', element: 'screen_capture_annotate' };
|
2020-11-27 10:07:46 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...defaultProps} />);
|
|
|
|
const area = wrapper.find('[data-testid="annotate-area"]');
|
|
|
|
area.simulate('mousedown', { pageX: 2, pageY: 49 });
|
|
|
|
area.simulate('mouseup');
|
2020-12-18 07:11:15 -06:00
|
|
|
expect(spy).toBeCalledWith('snippet-analytics-data', expectedValue);
|
2020-11-27 10:07:46 -06:00
|
|
|
});
|
2020-12-03 10:22:06 -06:00
|
|
|
|
|
|
|
it('should send annotate_added_highlight event when drawn with highlight', () => {
|
|
|
|
const highlightProps = {
|
|
|
|
paths: [],
|
|
|
|
highlightColor: 'rgba(233, 0, 0, 0.64)',
|
|
|
|
penColor: 'rgba(38, 196, 58, 1)',
|
|
|
|
onChange: jest.fn(),
|
|
|
|
imageDimensions: { width: 800, height: 800 },
|
|
|
|
annotateAreaDimensions: { width: 800, height: 800 },
|
|
|
|
chosenTool: Tool.highlight,
|
|
|
|
screenSnippetPath: 'very-nice-path',
|
|
|
|
};
|
2020-12-10 06:18:23 -06:00
|
|
|
const spy = jest.spyOn(ipcRenderer, 'send');
|
|
|
|
const expectedValue = { type: 'annotate_added_highlight', element: 'screen_capture_annotate' };
|
2020-12-03 10:22:06 -06:00
|
|
|
const wrapper = mount(<AnnotateArea {...highlightProps} />);
|
|
|
|
const area = wrapper.find('[data-testid="annotate-area"]');
|
|
|
|
area.simulate('mousedown', { pageX: 2, pageY: 49 });
|
|
|
|
area.simulate('mouseup');
|
2020-12-18 07:11:15 -06:00
|
|
|
expect(spy).toBeCalledWith('snippet-analytics-data', expectedValue);
|
2020-12-03 10:22:06 -06:00
|
|
|
});
|
2020-11-13 07:41:20 -06:00
|
|
|
});
|