hedgedoc/cypress/integration/export.spec.ts

49 lines
1.5 KiB
TypeScript
Raw Normal View History

/*
* SPDX-FileCopyrightText: 2021 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.visit('/n/test')
cy.codemirrorFill(testContent)
2020-10-06 10:43:17 +00:00
})
it('Markdown', () => {
cy.get('[data-cy="menu-export"]')
2020-10-06 10:43:17 +00:00
.click()
cy.get('[data-cy="menu-export-markdown"]')
2020-10-06 10:43:17 +00:00
.click()
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()
2020-10-06 10:43:17 +00:00
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
})
})