2022-04-06 10:14:43 +00:00
|
|
|
import { EditorProviders } from '../../helpers/editor-providers'
|
|
|
|
import PdfLogsEntries from '../../../../frontend/js/features/pdf-preview/components/pdf-logs-entries'
|
2023-01-09 12:52:11 +00:00
|
|
|
import { detachChannel, testDetachChannel } from '../../helpers/detach-channel'
|
2022-04-06 10:14:43 +00:00
|
|
|
window.metaAttributesCache = new Map([['ol-debugPdfDetach', true]])
|
|
|
|
|
|
|
|
describe('<PdfLogsEntries/>', function () {
|
|
|
|
const fakeEntity = { type: 'doc' }
|
|
|
|
|
|
|
|
const logEntries = [
|
|
|
|
{
|
|
|
|
file: 'main.tex',
|
|
|
|
line: 9,
|
|
|
|
column: 8,
|
|
|
|
level: 'error',
|
|
|
|
message: 'LaTeX Error',
|
|
|
|
content: 'See the LaTeX manual',
|
|
|
|
raw: '',
|
|
|
|
ruleId: 'hint_misplaced_alignment_tab_character',
|
|
|
|
key: '',
|
|
|
|
},
|
|
|
|
]
|
|
|
|
|
2022-05-27 12:32:27 +00:00
|
|
|
let props: Record<string, any>
|
2022-04-06 10:14:43 +00:00
|
|
|
|
|
|
|
beforeEach(function () {
|
|
|
|
props = {
|
|
|
|
fileTreeManager: {
|
|
|
|
findEntityByPath: cy.stub().as('findEntityByPath').returns(fakeEntity),
|
|
|
|
},
|
|
|
|
editorManager: {
|
2022-10-18 08:46:53 +00:00
|
|
|
openDoc: cy.spy().as('openDoc'),
|
2022-04-06 10:14:43 +00:00
|
|
|
},
|
|
|
|
}
|
|
|
|
|
|
|
|
cy.interceptCompile()
|
|
|
|
cy.interceptEvents()
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(function () {
|
|
|
|
window.metaAttributesCache = new Map()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('displays human readable hint', function () {
|
2022-06-08 07:39:09 +00:00
|
|
|
cy.mount(
|
2022-04-06 10:14:43 +00:00
|
|
|
<EditorProviders {...props}>
|
|
|
|
<PdfLogsEntries entries={logEntries} />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
|
|
|
cy.contains('You have placed an alignment tab character')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('opens doc on click', function () {
|
2022-06-08 07:39:09 +00:00
|
|
|
cy.mount(
|
2022-04-06 10:14:43 +00:00
|
|
|
<EditorProviders {...props}>
|
|
|
|
<PdfLogsEntries entries={logEntries} />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
|
|
|
cy.findByRole('button', {
|
|
|
|
name: 'Navigate to log position in source code: main.tex, 9',
|
2023-01-09 12:52:11 +00:00
|
|
|
}).click()
|
|
|
|
|
|
|
|
cy.get('@findEntityByPath').should('be.calledOnce')
|
|
|
|
cy.get('@openDoc').should('be.calledOnceWith', fakeEntity, {
|
|
|
|
gotoLine: 9,
|
|
|
|
gotoColumn: 8,
|
2022-04-06 10:14:43 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('opens doc via detached action', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detacher']])
|
|
|
|
})
|
|
|
|
|
2022-06-08 07:39:09 +00:00
|
|
|
cy.mount(
|
2022-04-06 10:14:43 +00:00
|
|
|
<EditorProviders {...props}>
|
|
|
|
<PdfLogsEntries entries={logEntries} />
|
|
|
|
</EditorProviders>
|
|
|
|
).then(() => {
|
2023-01-09 12:52:11 +00:00
|
|
|
testDetachChannel.postMessage({
|
2022-04-06 10:14:43 +00:00
|
|
|
role: 'detached',
|
|
|
|
event: 'action-sync-to-entry',
|
|
|
|
data: {
|
|
|
|
args: [
|
|
|
|
{
|
|
|
|
file: 'main.tex',
|
|
|
|
line: 7,
|
|
|
|
column: 6,
|
|
|
|
},
|
|
|
|
],
|
|
|
|
},
|
|
|
|
})
|
2023-01-09 12:52:11 +00:00
|
|
|
})
|
2022-04-06 10:14:43 +00:00
|
|
|
|
2023-01-09 12:52:11 +00:00
|
|
|
cy.get('@findEntityByPath').should('be.calledOnce')
|
|
|
|
cy.get('@openDoc').should('be.calledOnceWith', fakeEntity, {
|
|
|
|
gotoLine: 7,
|
|
|
|
gotoColumn: 6,
|
2022-04-06 10:14:43 +00:00
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('sends open doc clicks via detached action', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detached']])
|
|
|
|
})
|
|
|
|
|
2022-06-08 07:39:09 +00:00
|
|
|
cy.mount(
|
2022-04-06 10:14:43 +00:00
|
|
|
<EditorProviders {...props}>
|
|
|
|
<PdfLogsEntries entries={logEntries} />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
2023-01-09 12:52:11 +00:00
|
|
|
cy.spy(detachChannel, 'postMessage').as('postDetachMessage')
|
|
|
|
|
2022-04-06 10:14:43 +00:00
|
|
|
cy.findByRole('button', {
|
|
|
|
name: 'Navigate to log position in source code: main.tex, 9',
|
2023-01-09 12:52:11 +00:00
|
|
|
}).click()
|
|
|
|
|
|
|
|
cy.get('@findEntityByPath').should('not.be.called')
|
|
|
|
cy.get('@openDoc').should('not.be.called')
|
|
|
|
cy.get('@postDetachMessage').should('be.calledWith', {
|
|
|
|
role: 'detached',
|
|
|
|
event: 'action-sync-to-entry',
|
|
|
|
data: {
|
|
|
|
args: [
|
|
|
|
{
|
|
|
|
file: 'main.tex',
|
|
|
|
line: 9,
|
|
|
|
column: 8,
|
2022-04-06 10:14:43 +00:00
|
|
|
},
|
2023-01-09 12:52:11 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
})
|
2022-04-06 10:14:43 +00:00
|
|
|
})
|
|
|
|
})
|