mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-18 07:33:27 +00:00
837ad6002f
Fix Layout Dropdown in History and File Views GitOrigin-RevId: 17792e6ec516ac9d72c050d5e2b83066fa34ed6d
150 lines
4.3 KiB
JavaScript
150 lines
4.3 KiB
JavaScript
import sinon from 'sinon'
|
|
import fetchMock from 'fetch-mock'
|
|
import { expect } from 'chai'
|
|
import { fireEvent, screen } from '@testing-library/react'
|
|
import LayoutDropdownButton from '../../../../../frontend/js/features/editor-navigation-toolbar/components/layout-dropdown-button'
|
|
import { renderWithEditorContext } from '../../../helpers/render-with-context'
|
|
import * as eventTracking from '../../../../../frontend/js/infrastructure/event-tracking'
|
|
|
|
const eventTrackingSpy = sinon.spy(eventTracking)
|
|
|
|
describe('<LayoutDropdownButton />', function () {
|
|
let openStub
|
|
const defaultUi = {
|
|
pdfLayout: 'flat',
|
|
view: 'pdf',
|
|
}
|
|
|
|
beforeEach(function () {
|
|
openStub = sinon.stub(window, 'open')
|
|
window.metaAttributesCache = new Map()
|
|
fetchMock.post('express:/project/:projectId/compile/stop', () => 204)
|
|
})
|
|
|
|
afterEach(function () {
|
|
openStub.restore()
|
|
window.metaAttributesCache = new Map()
|
|
fetchMock.restore()
|
|
})
|
|
|
|
it('should mark current layout option as selected', function () {
|
|
// Selected is aria-label, visually we show a checkmark
|
|
renderWithEditorContext(<LayoutDropdownButton />, { ui: defaultUi })
|
|
screen.getByRole('menuitem', {
|
|
name: 'Editor & PDF',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Selected PDF only (hide editor)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Editor only (hide PDF)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'PDF in separate tab',
|
|
})
|
|
})
|
|
|
|
it('should not select any option in history view', function () {
|
|
// Selected is aria-label, visually we show a checkmark
|
|
renderWithEditorContext(<LayoutDropdownButton />, {
|
|
ui: { ...defaultUi, view: 'history' },
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Editor & PDF',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'PDF only (hide editor)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Editor only (hide PDF)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'PDF in separate tab',
|
|
})
|
|
})
|
|
|
|
it('should treat file and editor views the same way', function () {
|
|
// Selected is aria-label, visually we show a checkmark
|
|
renderWithEditorContext(<LayoutDropdownButton />, {
|
|
ui: {
|
|
pdfLayout: 'flat',
|
|
view: 'file',
|
|
},
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Editor & PDF',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'PDF only (hide editor)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'Selected Editor only (hide PDF)',
|
|
})
|
|
screen.getByRole('menuitem', {
|
|
name: 'PDF in separate tab',
|
|
})
|
|
})
|
|
|
|
describe('on detach', function () {
|
|
beforeEach(function () {
|
|
renderWithEditorContext(<LayoutDropdownButton />, {
|
|
ui: { ...defaultUi, view: 'editor' },
|
|
})
|
|
|
|
const menuItem = screen.getByRole('menuitem', {
|
|
name: 'PDF in separate tab',
|
|
})
|
|
fireEvent.click(menuItem)
|
|
})
|
|
|
|
it('should show processing', function () {
|
|
screen.getByText('Layout processing')
|
|
})
|
|
|
|
it('should stop compile when detaching', function () {
|
|
expect(fetchMock.called('express:/project/:projectId/compile/stop')).to.be
|
|
.true
|
|
})
|
|
|
|
it('should record event', function () {
|
|
sinon.assert.calledWith(eventTrackingSpy.sendMB, 'project-layout-detach')
|
|
})
|
|
})
|
|
|
|
describe('on layout change / reattach', function () {
|
|
beforeEach(function () {
|
|
window.metaAttributesCache.set('ol-detachRole', 'detacher')
|
|
renderWithEditorContext(<LayoutDropdownButton />, {
|
|
ui: { ...defaultUi, view: 'editor' },
|
|
})
|
|
|
|
const menuItem = screen.getByRole('menuitem', {
|
|
name: 'Editor only (hide PDF)',
|
|
})
|
|
fireEvent.click(menuItem)
|
|
})
|
|
|
|
it('should not show processing', function () {
|
|
const processingText = screen.queryByText('Layout processing')
|
|
expect(processingText).to.not.exist
|
|
})
|
|
|
|
it('should record events', function () {
|
|
sinon.assert.calledWith(
|
|
eventTrackingSpy.sendMB,
|
|
'project-layout-reattach'
|
|
)
|
|
sinon.assert.calledWith(
|
|
eventTrackingSpy.sendMB,
|
|
'project-layout-change',
|
|
{ layout: 'flat', view: 'editor' }
|
|
)
|
|
})
|
|
|
|
it('should select new menu item', function () {
|
|
screen.getByRole('menuitem', {
|
|
name: 'Selected Editor only (hide PDF)',
|
|
})
|
|
})
|
|
})
|
|
})
|