forked from opensearch-project/OpenSearch-Dashboards
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
test: add test for resizable button and service
Signed-off-by: tygao <tygao@amazon.com>
- Loading branch information
Showing
10 changed files
with
291 additions
and
13 deletions.
There are no files selected for viewing
13 changes: 13 additions & 0 deletions
13
src/core/public/overlays/sidecar/__snapshots__/sidecar_service.test.tsx.snap
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
67 changes: 67 additions & 0 deletions
67
src/core/public/overlays/sidecar/components/__snapshots__/resizable_button.test.tsx.snap
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
File renamed without changes.
92 changes: 92 additions & 0 deletions
92
src/core/public/overlays/sidecar/components/resizable_button.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,92 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
import React from 'react'; | ||
|
||
import { ResizableButton, MIN_SIDECAR_SIZE } from './resizable_button'; | ||
import { shallow } from 'enzyme'; | ||
import { SIDECAR_DOCKED_MODE } from '../sidecar_service'; | ||
|
||
const storeWindowEvents = () => { | ||
const map: Record<string, Function> = {}; | ||
window.addEventListener = jest.fn().mockImplementation((event: string, cb) => { | ||
map[event] = cb; | ||
}); | ||
return map; | ||
}; | ||
|
||
const DEFAULT_FLYOUT_SIZE = 460; | ||
const props = { | ||
dockedMode: SIDECAR_DOCKED_MODE.RIGHT, | ||
onResize: jest.fn(), | ||
flyoutSize: DEFAULT_FLYOUT_SIZE, | ||
}; | ||
|
||
test('is rendered', () => { | ||
const component = shallow(<ResizableButton {...props} />); | ||
expect(component).toMatchSnapshot(); | ||
}); | ||
|
||
test('it should be horizontal when docked mode is right', () => { | ||
const component = shallow(<ResizableButton {...props} />); | ||
expect(component.hasClass('resizableButton--horizontal')).toBe(true); | ||
expect(component.hasClass('resizableButton--vertical')).toBe(false); | ||
expect(component).toMatchSnapshot(); | ||
}); | ||
|
||
test('it should be vertical when docked mode is takeover', () => { | ||
const newProps = { ...props, dockedMode: SIDECAR_DOCKED_MODE.TAKEOVER }; | ||
const component = shallow(<ResizableButton {...newProps} />); | ||
expect(component.hasClass('resizableButton--vertical')).toBe(true); | ||
expect(component.hasClass('resizableButton--horizontal')).toBe(false); | ||
expect(component).toMatchSnapshot(); | ||
}); | ||
|
||
test('it should emit onResize with new flyout size when drag and horizontal', () => { | ||
const windowEvents = storeWindowEvents(); | ||
|
||
const onResize = jest.fn(); | ||
const newProps = { ...props, onResize }; | ||
const component = shallow(<ResizableButton {...newProps} />); | ||
const resizer = component.find(`[data-test-subj~="resizableButton"]`).first(); | ||
expect(onResize).not.toHaveBeenCalled(); | ||
resizer.simulate('mousedown', { clientX: 0, pageX: 0, pageY: 0 }); | ||
windowEvents?.mousemove({ clientX: -1000, pageX: 0, pageY: 0 }); | ||
windowEvents?.mouseup(); | ||
const newSize = 1000 + DEFAULT_FLYOUT_SIZE; | ||
expect(onResize).toHaveBeenCalledWith(newSize); | ||
expect(component).toMatchSnapshot(); | ||
}); | ||
|
||
test('it should emit onResize with new flyout size when drag and vertical', () => { | ||
const windowEvents = storeWindowEvents(); | ||
|
||
const onResize = jest.fn(); | ||
const newProps = { ...props, onResize, dockedMode: SIDECAR_DOCKED_MODE.TAKEOVER }; | ||
const component = shallow(<ResizableButton {...newProps} />); | ||
const resizer = component.find(`[data-test-subj~="resizableButton"]`).first(); | ||
expect(onResize).not.toHaveBeenCalled(); | ||
resizer.simulate('mousedown', { clientY: 0, pageX: 0, pageY: 0 }); | ||
windowEvents?.mousemove({ clientY: -1000, pageX: 0, pageY: 0 }); | ||
windowEvents?.mouseup(); | ||
const newSize = 1000 + DEFAULT_FLYOUT_SIZE; | ||
expect(onResize).toHaveBeenCalledWith(newSize); | ||
expect(component).toMatchSnapshot(); | ||
}); | ||
|
||
test('it should emit onResize with min size when drag if new size is below the minimum', () => { | ||
const windowEvents = storeWindowEvents(); | ||
const onResize = jest.fn(); | ||
const newProps = { ...props, onResize }; | ||
const component = shallow(<ResizableButton {...newProps} />); | ||
const resizer = component.find(`[data-test-subj~="resizableButton"]`).first(); | ||
expect(onResize).not.toHaveBeenCalled(); | ||
resizer.simulate('mousedown', { clientX: 0, pageX: 0, pageY: 0 }); | ||
windowEvents?.mousemove({ clientX: 1000, pageX: 0, pageY: 0 }); | ||
windowEvents?.mouseup(); | ||
const newSize = MIN_SIDECAR_SIZE; | ||
expect(onResize).toHaveBeenCalledWith(newSize); | ||
expect(component).toMatchSnapshot(); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
107 changes: 107 additions & 0 deletions
107
src/core/public/overlays/sidecar/sidecar_service.test.tsx
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,107 @@ | ||
/* | ||
* Copyright OpenSearch Contributors | ||
* SPDX-License-Identifier: Apache-2.0 | ||
*/ | ||
|
||
import { mockReactDomRender, mockReactDomUnmount } from '../overlay.test.mocks'; | ||
|
||
import { mount } from 'enzyme'; | ||
import { i18nServiceMock } from '../../i18n/i18n_service.mock'; | ||
import { | ||
SidecarService, | ||
OverlaySidecarStart, | ||
OverlaySidecarOpenOptions, | ||
SIDECAR_DOCKED_MODE, | ||
} from './sidecar_service'; | ||
import { OverlayRef } from '../types'; | ||
|
||
const i18nMock = i18nServiceMock.createStartContract(); | ||
|
||
beforeEach(() => { | ||
mockReactDomRender.mockClear(); | ||
mockReactDomUnmount.mockClear(); | ||
}); | ||
|
||
const mountText = (text: string) => (container: HTMLElement) => { | ||
const content = document.createElement('span'); | ||
content.textContent = text; | ||
container.append(content); | ||
return () => {}; | ||
}; | ||
|
||
const getServiceStart = () => { | ||
const service = new SidecarService(); | ||
return service.start({ i18n: i18nMock, targetDomElement: document.createElement('div') }); | ||
}; | ||
|
||
describe('SidecarService', () => { | ||
let sidecar: OverlaySidecarStart; | ||
const options: OverlaySidecarOpenOptions = { | ||
config: { | ||
dockedMode: SIDECAR_DOCKED_MODE.RIGHT, | ||
paddingSize: 460, | ||
}, | ||
}; | ||
beforeEach(() => { | ||
sidecar = getServiceStart(); | ||
}); | ||
|
||
describe('openSidecar()', () => { | ||
it('renders a sidecar to the DOM', () => { | ||
expect(mockReactDomRender).not.toHaveBeenCalled(); | ||
sidecar.open(mountText('Sidecar content'), options); | ||
const content = mount(mockReactDomRender.mock.calls[0][0]); | ||
expect(content.html()).toMatchSnapshot(); | ||
}); | ||
describe('with a currently active sidecar', () => { | ||
let ref1: OverlayRef; | ||
beforeEach(() => { | ||
ref1 = sidecar.open(mountText('Sidecar content'), options); | ||
}); | ||
it('replaces the current sidecar with a new one', () => { | ||
sidecar.open(mountText('Sidecar content 2'), options); | ||
expect(mockReactDomUnmount).toHaveBeenCalledTimes(1); | ||
const modalContent = mount(mockReactDomRender.mock.calls[1][0]); | ||
expect(modalContent.html()).toMatchSnapshot(); | ||
expect(() => ref1.close()).not.toThrowError(); | ||
expect(mockReactDomUnmount).toHaveBeenCalledTimes(1); | ||
}); | ||
it('resolves onClose on the previous ref', async () => { | ||
const onCloseComplete = jest.fn(); | ||
ref1.onClose.then(onCloseComplete); | ||
sidecar.open(mountText('Sidecar content 2'), options); | ||
await ref1.onClose; | ||
expect(onCloseComplete).toBeCalledTimes(1); | ||
}); | ||
}); | ||
}); | ||
describe('SidecarRef#close()', () => { | ||
it('resolves the onClose Promise', async () => { | ||
const ref = sidecar.open(mountText('Sidecar content'), options); | ||
|
||
const onCloseComplete = jest.fn(); | ||
ref.onClose.then(onCloseComplete); | ||
await ref.close(); | ||
await ref.close(); | ||
expect(onCloseComplete).toHaveBeenCalledTimes(1); | ||
}); | ||
it('can be called multiple times on the same SidecarRef', async () => { | ||
const ref = sidecar.open(mountText('Sidecar content'), options); | ||
expect(mockReactDomUnmount).not.toHaveBeenCalled(); | ||
await ref.close(); | ||
expect(mockReactDomUnmount.mock.calls).toMatchSnapshot(); | ||
await ref.close(); | ||
expect(mockReactDomUnmount).toHaveBeenCalledTimes(1); | ||
}); | ||
it("on a stale Sidecar doesn't affect the active sidecar", async () => { | ||
const ref1 = sidecar.open(mountText('Sidecar content 1'), options); | ||
const ref2 = sidecar.open(mountText('Sidecar content 2'), options); | ||
const onCloseComplete = jest.fn(); | ||
ref2.onClose.then(onCloseComplete); | ||
mockReactDomUnmount.mockClear(); | ||
await ref1.close(); | ||
expect(mockReactDomUnmount).toBeCalledTimes(0); | ||
expect(onCloseComplete).toBeCalledTimes(0); | ||
}); | ||
}); | ||
}); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters