2020-11-09 14:52:22 +00:00
|
|
|
import React from 'react'
|
|
|
|
import sinon from 'sinon'
|
|
|
|
import { expect } from 'chai'
|
2020-12-02 10:03:03 +00:00
|
|
|
import { screen, render, fireEvent } from '@testing-library/react'
|
2020-11-09 14:52:22 +00:00
|
|
|
import PreviewToolbar from '../../../../../frontend/js/features/preview/components/preview-toolbar'
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
describe('<PreviewToolbar />', function () {
|
2020-11-09 14:52:22 +00:00
|
|
|
const onRecompile = sinon.stub()
|
2020-12-02 10:03:03 +00:00
|
|
|
const onRecompileFromScratch = sinon.stub()
|
2020-11-09 14:52:22 +00:00
|
|
|
const onRunSyntaxCheckNow = sinon.stub()
|
|
|
|
const onSetAutoCompile = sinon.stub()
|
|
|
|
const onSetDraftMode = sinon.stub()
|
|
|
|
const onSetSyntaxCheck = sinon.stub()
|
|
|
|
const onToggleLogs = sinon.stub()
|
2020-12-02 10:03:03 +00:00
|
|
|
const onSetSplitLayout = sinon.stub()
|
|
|
|
const onSetFullLayout = sinon.stub()
|
|
|
|
const onStopCompilation = sinon.stub()
|
2020-11-09 14:52:22 +00:00
|
|
|
|
2020-12-02 10:03:03 +00:00
|
|
|
function renderPreviewToolbar(
|
|
|
|
compilerState = {},
|
|
|
|
logState = {},
|
|
|
|
showLogs = false,
|
|
|
|
splitLayout = true
|
|
|
|
) {
|
2020-11-09 14:52:22 +00:00
|
|
|
render(
|
|
|
|
<PreviewToolbar
|
|
|
|
compilerState={{
|
2021-03-18 13:49:01 +00:00
|
|
|
autoCompileHasChanges: true,
|
2020-11-09 14:52:22 +00:00
|
|
|
isAutoCompileOn: true,
|
|
|
|
isClearingCache: false,
|
|
|
|
isCompiling: false,
|
|
|
|
isDraftModeOn: false,
|
|
|
|
isSyntaxCheckOn: false,
|
|
|
|
logEntries: {},
|
|
|
|
...compilerState
|
|
|
|
}}
|
2021-03-18 13:49:01 +00:00
|
|
|
logsState={{ nErrors: 0, nWarnings: 0, ...logState }}
|
2020-11-09 14:52:22 +00:00
|
|
|
onRecompile={onRecompile}
|
2020-12-02 10:03:03 +00:00
|
|
|
onRecompileFromScratch={onRecompileFromScratch}
|
2020-11-09 14:52:22 +00:00
|
|
|
onRunSyntaxCheckNow={onRunSyntaxCheckNow}
|
|
|
|
onSetAutoCompile={onSetAutoCompile}
|
|
|
|
onSetDraftMode={onSetDraftMode}
|
|
|
|
onSetSyntaxCheck={onSetSyntaxCheck}
|
|
|
|
onToggleLogs={onToggleLogs}
|
|
|
|
outputFiles={[]}
|
|
|
|
pdfDownloadUrl="/download-pdf-url"
|
2020-12-02 10:03:03 +00:00
|
|
|
showLogs={showLogs}
|
|
|
|
splitLayout={splitLayout}
|
|
|
|
onSetSplitLayout={onSetSplitLayout}
|
|
|
|
onSetFullLayout={onSetFullLayout}
|
|
|
|
onStopCompilation={onStopCompilation}
|
2020-11-09 14:52:22 +00:00
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('renders the toolbar', function () {
|
2020-11-09 14:52:22 +00:00
|
|
|
renderPreviewToolbar()
|
|
|
|
screen.getByText('Recompile')
|
|
|
|
screen.getByText('Download PDF')
|
|
|
|
screen.getByText('View logs')
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('all toolbar items have "toolbar-item" class and text has "toolbar-text"', function () {
|
2020-11-09 14:52:22 +00:00
|
|
|
renderPreviewToolbar()
|
|
|
|
const toolbar = screen.getByTestId('toolbar-preview')
|
|
|
|
for (const toolbarSection of toolbar.children) {
|
|
|
|
for (const toolbarItem of toolbarSection.children) {
|
|
|
|
expect(toolbarItem.className).to.contain('toolbar-item')
|
|
|
|
for (const parts of toolbarItem.children) {
|
|
|
|
for (const part of parts.children) {
|
|
|
|
if (part.nodeName !== 'LI' && part.textContent) {
|
|
|
|
expect(part.className).to.contain('toolbar-text')
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
})
|
2020-12-02 10:03:03 +00:00
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('renders a full-screen button with a tooltip when when in split-screen mode', function () {
|
2020-12-02 10:03:03 +00:00
|
|
|
renderPreviewToolbar()
|
|
|
|
const btn = screen.getByLabelText('Full screen')
|
|
|
|
fireEvent.click(btn)
|
|
|
|
expect(onSetFullLayout).to.have.been.calledOnce
|
|
|
|
fireEvent.mouseOver(btn)
|
|
|
|
screen.getByRole('tooltip', { name: 'Full screen' })
|
|
|
|
})
|
|
|
|
|
2021-04-14 13:17:21 +00:00
|
|
|
it('renders a split-screen button with a tooltip when when in full-screen mode', function () {
|
2020-12-02 10:03:03 +00:00
|
|
|
renderPreviewToolbar({}, {}, false, false)
|
|
|
|
const btn = screen.getByLabelText('Split screen')
|
|
|
|
fireEvent.click(btn)
|
|
|
|
expect(onSetSplitLayout).to.have.been.calledOnce
|
|
|
|
fireEvent.mouseOver(btn)
|
|
|
|
screen.getByRole('tooltip', { name: 'Split screen' })
|
|
|
|
})
|
2020-11-09 14:52:22 +00:00
|
|
|
})
|