hedgedoc/frontend/cypress/e2e/export.spec.ts

48 lines
1.5 KiB
TypeScript
Raw Normal View History

/*
* SPDX-FileCopyrightText: 2022 The HedgeDoc developers (see AUTHORS file)
*
* SPDX-License-Identifier: AGPL-3.0-only
*/
2020-10-06 10:43:17 +00:00
describe('Export', () => {
const testTitle = 'testContent'
const testContent = `---\ntitle: ${testTitle}\n---\nThis is some test content`
2020-10-06 10:43:17 +00:00
beforeEach(() => {
cy.visitTestNote()
cy.setCodemirrorContent(testContent)
2020-10-06 10:43:17 +00:00
})
it('Markdown', () => {
cy.getByCypressId('menu-export').click()
cy.getByCypressId('menu-export-markdown').click()
2020-10-06 10:43:17 +00:00
cy.get('a[download]')
.then(
(anchor) =>
new Cypress.Promise((resolve: any, _: any) => {
// Use XHR to get the blob that corresponds to the object URL.
const xhr = new XMLHttpRequest()
xhr.open('GET', anchor.prop('href'), true)
xhr.responseType = 'blob'
2020-10-06 10:43:17 +00:00
// Once loaded, use FileReader to get the string back from the blob.
xhr.onload = () => {
if (xhr.status === 200) {
const blob = xhr.response
const reader = new FileReader()
reader.onload = () => {
// Once we have a string, resolve the promise to let
// the Cypress chain continue, e.g. to assert on the result.
resolve(reader.result)
}
reader.readAsText(blob)
}
2020-10-06 10:43:17 +00:00
}
xhr.send()
})
)
2020-10-06 10:43:17 +00:00
// Now the regular Cypress assertions should work.
.should('equal', testContent)
2020-10-06 10:43:17 +00:00
})
})