mirror of
https://github.com/overleaf/overleaf.git
synced 2024-11-07 20:31:06 -05:00
4e74fb2694
* Ordering of log entries in the new errors UI * Don't show the expand-collapse widget when not needed; smaller font size in the raw log output * Expose log actions in the log pane. * Use "This project" instead of "Your project" in the new errors UI * Better handling of long log messages; left-ellipsize the file/line number button * Make log location more button-like; add tooltip when needed. * Add a PDF expand button to the toolbar. * Add a stop compilation button to the new compile UI * Use aria-label for button accessible text; improve handling of long filenames in the log location button * Set max-height correctly for the logs pane dropdown * Avoid changing raw logs sizing when expanded and collapsed * Add comment on the solution for right-to-left text and ellipsis * Improve logs pane actions GitOrigin-RevId: 4098d77a9ee6d333644906876b9ff27035b79319
117 lines
3.6 KiB
JavaScript
117 lines
3.6 KiB
JavaScript
import React from 'react'
|
|
import sinon from 'sinon'
|
|
import { screen, render, fireEvent } from '@testing-library/react'
|
|
import PreviewRecompileButton from '../../../../../frontend/js/features/preview/components/preview-recompile-button'
|
|
const { expect } = require('chai')
|
|
|
|
describe('<PreviewRecompileButton />', function() {
|
|
let onRecompile, onRecompileFromScratch, onStopCompilation
|
|
|
|
beforeEach(function() {
|
|
onRecompile = sinon.stub().resolves()
|
|
onRecompileFromScratch = sinon.stub().resolves()
|
|
onStopCompilation = sinon.stub().resolves()
|
|
})
|
|
|
|
it('renders all items', function() {
|
|
renderPreviewRecompileButton()
|
|
|
|
const menuItems = screen.getAllByRole('menuitem')
|
|
expect(menuItems.length).to.equal(9)
|
|
expect(menuItems.map(item => item.textContent)).to.deep.equal([
|
|
'On',
|
|
'Off',
|
|
'Normal',
|
|
'Fast [draft]',
|
|
'Check syntax before compile',
|
|
"Don't check syntax",
|
|
'Run syntax check now',
|
|
'Stop compilation',
|
|
'Recompile from scratch'
|
|
])
|
|
|
|
const menuHeadingItems = screen.getAllByRole('heading')
|
|
expect(menuHeadingItems.length).to.equal(3)
|
|
expect(menuHeadingItems.map(item => item.textContent)).to.deep.equal([
|
|
'Auto Compile',
|
|
'Compile Mode',
|
|
'Syntax Checks'
|
|
])
|
|
})
|
|
|
|
describe('Recompile from scratch', function() {
|
|
describe('click', function() {
|
|
it('should call onRecompileFromScratch', async function() {
|
|
renderPreviewRecompileButton()
|
|
|
|
const button = screen.getByRole('menuitem', {
|
|
name: 'Recompile from scratch'
|
|
})
|
|
await fireEvent.click(button)
|
|
expect(onRecompileFromScratch).to.have.been.calledOnce
|
|
})
|
|
})
|
|
describe('processing', function() {
|
|
it('shows processing view and disable menuItem when recompiling', function() {
|
|
renderPreviewRecompileButton({ isCompiling: true })
|
|
|
|
screen.getByRole('button', { name: 'Compiling …' })
|
|
expect(
|
|
screen
|
|
.getByRole('menuitem', {
|
|
name: 'Recompile from scratch'
|
|
})
|
|
.getAttribute('aria-disabled')
|
|
).to.equal('true')
|
|
expect(
|
|
screen
|
|
.getByRole('menuitem', {
|
|
name: 'Recompile from scratch'
|
|
})
|
|
.closest('li')
|
|
.getAttribute('class')
|
|
).to.equal('disabled')
|
|
})
|
|
})
|
|
})
|
|
|
|
it('should show the button text when prop showText=true', function() {
|
|
const showText = true
|
|
renderPreviewRecompileButton({}, showText)
|
|
expect(screen.getByText('Recompile').getAttribute('style')).to.be.null
|
|
})
|
|
it('should not show the button text when prop showText=false', function() {
|
|
const showText = false
|
|
renderPreviewRecompileButton({}, showText)
|
|
expect(screen.getByText('Recompile').getAttribute('style')).to.equal(
|
|
'position: absolute; right: -100vw;'
|
|
)
|
|
})
|
|
|
|
function renderPreviewRecompileButton(compilerState = {}, showText) {
|
|
if (!compilerState.logEntries) {
|
|
compilerState.logEntries = {}
|
|
}
|
|
if (showText === undefined) showText = true
|
|
render(
|
|
<PreviewRecompileButton
|
|
compilerState={{
|
|
isAutoCompileOn: true,
|
|
isClearingCache: false,
|
|
isCompiling: false,
|
|
isDraftModeOn: false,
|
|
isSyntaxCheckOn: false,
|
|
...compilerState
|
|
}}
|
|
onRecompile={onRecompile}
|
|
onRunSyntaxCheckNow={() => {}}
|
|
onSetAutoCompile={() => {}}
|
|
onSetDraftMode={() => {}}
|
|
onSetSyntaxCheck={() => {}}
|
|
onRecompileFromScratch={onRecompileFromScratch}
|
|
onStopCompilation={onStopCompilation}
|
|
showText={showText}
|
|
/>
|
|
)
|
|
}
|
|
})
|