DEV: Make smoke tests more reliable
This commit is contained in:
parent
452d541b74
commit
d4d2cb124c
|
@ -16,8 +16,8 @@ const path = require("path");
|
||||||
|
|
||||||
(async () => {
|
(async () => {
|
||||||
const browser = await puppeteer.launch({
|
const browser = await puppeteer.launch({
|
||||||
// when debugging localy setting headless to "false" can be very helpful
|
// when debugging localy setting the SHOW_BROWSER env variable can be very helpful
|
||||||
headless: true,
|
headless: process.env.SHOW_BROWSER === undefined,
|
||||||
args: ["--disable-local-storage", "--no-sandbox"]
|
args: ["--disable-local-storage", "--no-sandbox"]
|
||||||
});
|
});
|
||||||
const page = await browser.newPage();
|
const page = await browser.newPage();
|
||||||
|
@ -209,17 +209,19 @@ const path = require("path");
|
||||||
});
|
});
|
||||||
|
|
||||||
await exec("upload modal is open", () => {
|
await exec("upload modal is open", () => {
|
||||||
let promise = page.waitForSelector("#filename-input", { visible: true });
|
return page.waitForSelector("#filename-input", { visible: true });
|
||||||
|
});
|
||||||
|
|
||||||
promise.then(() => {
|
await exec("upload modal closes", () => {
|
||||||
return page.click(".d-modal-cancel");
|
let promise = page.click(".d-modal-cancel");
|
||||||
|
|
||||||
|
promise = promise.then(() => {
|
||||||
|
return page.waitForSelector("#filename-input", { hidden: true });
|
||||||
});
|
});
|
||||||
|
|
||||||
return promise;
|
return promise;
|
||||||
});
|
});
|
||||||
|
|
||||||
await page.waitFor(1000);
|
|
||||||
|
|
||||||
await exec("submit the topic", () => {
|
await exec("submit the topic", () => {
|
||||||
return page.click(".submit-panel .create");
|
return page.click(".submit-panel .create");
|
||||||
});
|
});
|
||||||
|
@ -250,78 +252,98 @@ const path = require("path");
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
await page.waitFor(5000);
|
await exec("submit the reply", () => {
|
||||||
|
let promise = page.click("#reply-control .create");
|
||||||
await exec("submit the topic", () => {
|
|
||||||
return page.click("#reply-control .create");
|
|
||||||
});
|
|
||||||
|
|
||||||
await assert(
|
|
||||||
"reply is created",
|
|
||||||
() => {
|
|
||||||
let promise = page.waitForSelector(".topic-post");
|
|
||||||
|
|
||||||
promise = promise.then(() => {
|
promise = promise.then(() => {
|
||||||
return page.evaluate(() => {
|
return page.waitForSelector("#reply-control.closed", {
|
||||||
return document.querySelectorAll(".topic-post").length;
|
visible: false
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
return promise;
|
return promise;
|
||||||
},
|
});
|
||||||
output => {
|
|
||||||
return output === 2;
|
await assert("reply is created", () => {
|
||||||
|
let promise = page.waitForSelector(
|
||||||
|
".topic-post:not(.staged) #post_2 .cooked",
|
||||||
|
{
|
||||||
|
visible: true
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
await page.waitFor(1000);
|
promise = promise.then(() => {
|
||||||
|
return page.waitForFunction(
|
||||||
|
"document.querySelector('#post_2 .cooked').innerText.includes('I can even write a reply')"
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
return promise;
|
||||||
|
});
|
||||||
|
|
||||||
|
await exec("wait a little bit", () => {
|
||||||
|
return page.waitFor(5000);
|
||||||
|
});
|
||||||
|
|
||||||
await exec("open composer to edit first post", () => {
|
await exec("open composer to edit first post", () => {
|
||||||
return page.click(".post-controls:first-of-type .edit");
|
let promise = page.evaluate(() => {
|
||||||
|
window.scrollTo(0, 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
promise = promise.then(() => {
|
||||||
|
return page.click("#post_1 .post-controls .edit");
|
||||||
|
});
|
||||||
|
|
||||||
|
promise = promise.then(() => {
|
||||||
|
return page.waitForSelector("#reply-control .d-editor-input", {
|
||||||
|
visible: true
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
return promise;
|
||||||
});
|
});
|
||||||
|
|
||||||
await exec("update post raw in composer", () => {
|
await exec("update post raw in composer", () => {
|
||||||
let promise = page.waitForSelector("#reply-control .d-editor-input", {
|
let promise = page.waitFor(5000);
|
||||||
visible: true
|
|
||||||
});
|
|
||||||
|
|
||||||
promise = promise.then(() => page.waitFor(5000));
|
|
||||||
|
|
||||||
promise = promise.then(() => {
|
promise = promise.then(() => {
|
||||||
const post = `I edited this post`;
|
return page.type(
|
||||||
return page.type("#reply-control .d-editor-input", post);
|
"#reply-control .d-editor-input",
|
||||||
|
"\n\nI edited this post"
|
||||||
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
return promise;
|
return promise;
|
||||||
});
|
});
|
||||||
|
|
||||||
await exec("submit the edit", () => {
|
await exec("submit the edit", () => {
|
||||||
return page.click("#reply-control .create");
|
let promise = page.click("#reply-control .create");
|
||||||
});
|
|
||||||
|
|
||||||
await assert(
|
promise = promise.then(() => {
|
||||||
"reply is created",
|
return page.waitForSelector("#reply-control.closed", {
|
||||||
() => {
|
|
||||||
let promise = page.waitForSelector("#reply-control.closed", {
|
|
||||||
visible: false
|
visible: false
|
||||||
});
|
});
|
||||||
|
|
||||||
promise = promise.then(() => {
|
|
||||||
return page.waitForSelector("#post_1", { visible: true });
|
|
||||||
});
|
|
||||||
|
|
||||||
promise = promise.then(() => {
|
|
||||||
return page.evaluate(() => {
|
|
||||||
return document.querySelector("#post_1 .cooked").textContent;
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return promise;
|
return promise;
|
||||||
},
|
});
|
||||||
output => {
|
|
||||||
return output.includes(`I edited this post`);
|
await assert("edit is successful", () => {
|
||||||
|
let promise = page.waitForSelector(
|
||||||
|
".topic-post:not(.staged) #post_1 .cooked",
|
||||||
|
{
|
||||||
|
visible: true
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
|
|
||||||
|
promise = promise.then(() => {
|
||||||
|
return page.waitForFunction(
|
||||||
|
"document.querySelector('#post_1 .cooked').innerText.includes('I edited this post')"
|
||||||
|
);
|
||||||
|
});
|
||||||
|
|
||||||
|
return promise;
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
await exec("close browser", () => {
|
await exec("close browser", () => {
|
||||||
|
|
Loading…
Reference in New Issue