2022-04-06 06:14:43 -04:00
|
|
|
import sysendTestHelper from '../../helpers/sysend'
|
|
|
|
import { EditorProviders } from '../../helpers/editor-providers'
|
|
|
|
import PdfPreviewHybridToolbar from '../../../../frontend/js/features/pdf-preview/components/pdf-preview-hybrid-toolbar'
|
|
|
|
|
|
|
|
describe('<PdfPreviewHybridToolbar/>', function () {
|
|
|
|
beforeEach(function () {
|
|
|
|
cy.interceptCompile()
|
|
|
|
cy.interceptEvents()
|
|
|
|
})
|
|
|
|
|
|
|
|
afterEach(function () {
|
|
|
|
window.metaAttributesCache = new Map()
|
|
|
|
sysendTestHelper.resetHistory()
|
|
|
|
})
|
|
|
|
|
|
|
|
it('shows normal mode', function () {
|
2022-06-08 03:39:09 -04:00
|
|
|
cy.mount(
|
2022-04-06 06:14:43 -04:00
|
|
|
<EditorProviders>
|
|
|
|
<PdfPreviewHybridToolbar />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
|
|
|
cy.findByRole('button', { name: 'Recompile' })
|
|
|
|
})
|
|
|
|
|
|
|
|
describe('orphan mode', function () {
|
|
|
|
it('shows connecting message on load', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detached']])
|
|
|
|
})
|
|
|
|
|
2022-06-08 03:39:09 -04:00
|
|
|
cy.mount(
|
2022-04-06 06:14:43 -04:00
|
|
|
<EditorProviders>
|
|
|
|
<PdfPreviewHybridToolbar />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
|
|
|
cy.contains('Connecting with the editor')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('shows compile UI when connected', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detached']])
|
|
|
|
})
|
|
|
|
|
2022-06-08 03:39:09 -04:00
|
|
|
cy.mount(
|
2022-04-06 06:14:43 -04:00
|
|
|
<EditorProviders>
|
|
|
|
<PdfPreviewHybridToolbar />
|
|
|
|
</EditorProviders>
|
|
|
|
).then(() => {
|
|
|
|
sysendTestHelper.receiveMessage({
|
|
|
|
role: 'detacher',
|
|
|
|
event: 'connected',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.findByRole('button', { name: 'Recompile' })
|
|
|
|
})
|
|
|
|
|
|
|
|
it('shows connecting message when disconnected', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detached']])
|
|
|
|
})
|
|
|
|
|
2022-06-08 03:39:09 -04:00
|
|
|
cy.mount(
|
2022-04-06 06:14:43 -04:00
|
|
|
<EditorProviders>
|
|
|
|
<PdfPreviewHybridToolbar />
|
|
|
|
</EditorProviders>
|
|
|
|
).then(() => {
|
|
|
|
sysendTestHelper.receiveMessage({
|
|
|
|
role: 'detacher',
|
|
|
|
event: 'connected',
|
|
|
|
})
|
|
|
|
sysendTestHelper.receiveMessage({
|
|
|
|
role: 'detacher',
|
|
|
|
event: 'closed',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.contains('Connecting with the editor')
|
|
|
|
})
|
|
|
|
|
|
|
|
it('shows redirect button after timeout', function () {
|
|
|
|
cy.window().then(win => {
|
|
|
|
win.metaAttributesCache = new Map([['ol-detachRole', 'detached']])
|
|
|
|
})
|
|
|
|
|
|
|
|
cy.clock()
|
|
|
|
|
2022-06-08 03:39:09 -04:00
|
|
|
cy.mount(
|
2022-04-06 06:14:43 -04:00
|
|
|
<EditorProviders>
|
|
|
|
<PdfPreviewHybridToolbar />
|
|
|
|
</EditorProviders>
|
|
|
|
)
|
|
|
|
|
|
|
|
cy.tick(6000)
|
|
|
|
|
|
|
|
cy.findByRole('button', { name: 'Redirect to editor' })
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|