test: use polling for more stable markdown e2e tests

close #1908
This commit is contained in:
Evan You 2020-08-20 10:51:25 -04:00
parent d4cc7b2496
commit a74f8d7891
2 changed files with 25 additions and 3 deletions

View File

@ -6,6 +6,24 @@ const puppeteerOptions = process.env.CI
? { args: ['--no-sandbox', '--disable-setuid-sandbox'] } ? { args: ['--no-sandbox', '--disable-setuid-sandbox'] }
: {} : {}
const maxTries = 20
export const timeout = (n: number) => new Promise(r => setTimeout(r, n))
export async function expectByPolling(
poll: () => Promise<any>,
expected: string
) {
for (let tries = 0; tries < maxTries; tries++) {
const actual = (await poll()) || ''
if (actual.indexOf(expected) > -1 || tries === maxTries - 1) {
expect(actual).toMatch(expected)
break
} else {
await timeout(50)
}
}
}
export function setupPuppeteer() { export function setupPuppeteer() {
let browser: puppeteer.Browser let browser: puppeteer.Browser
let page: puppeteer.Page let page: puppeteer.Page

View File

@ -1,5 +1,9 @@
import path from 'path' import path from 'path'
import { setupPuppeteer, E2E_TIMEOUT } from '../../__tests__/e2eUtils' import {
setupPuppeteer,
expectByPolling,
E2E_TIMEOUT
} from '../../__tests__/e2eUtils'
describe('e2e: markdown', () => { describe('e2e: markdown', () => {
const { page, isVisible, value, html } = setupPuppeteer() const { page, isVisible, value, html } = setupPuppeteer()
@ -18,8 +22,8 @@ describe('e2e: markdown', () => {
await page().type('textarea', '\n## foo\n\n- bar\n- baz') await page().type('textarea', '\n## foo\n\n- bar\n- baz')
// assert the output is not updated yet because of debounce // assert the output is not updated yet because of debounce
expect(await html('#editor div')).toBe('<h1 id="hello">hello</h1>\n') expect(await html('#editor div')).toBe('<h1 id="hello">hello</h1>\n')
await page().waitFor(200) await expectByPolling(
expect(await html('#editor div')).toBe( () => html('#editor div'),
'<h1 id="hello">hello</h1>\n' + '<h1 id="hello">hello</h1>\n' +
'<h2 id="foo">foo</h2>\n' + '<h2 id="foo">foo</h2>\n' +
'<ul>\n<li>bar</li>\n<li>baz</li>\n</ul>\n' '<ul>\n<li>bar</li>\n<li>baz</li>\n</ul>\n'