import { strict as assert } from "node:assert"; import { describe, it, before, after } from "mocha"; import puppeteer from "puppeteer-core"; import { setReviewForm, checkCorrectness } from "./appTestHelpers.js"; describe("test App end to end", async () => { let browser; let page; before(async () => { let root; try { root = process.getuid() == 0; } catch (error) { root = false; } browser = await puppeteer.launch({ args: root ? ["--no-sandbox"] : undefined }); page = await browser.newPage(); try { await page.goto("http://localhost:8080", { timeout: 2000 }); await console.log(`✔ connected to localhost webserver as ${root ? "root" : "user"}`); } catch (error) { await console.log("❌ failed to connect to localhost webserver on port 8080"); } }); describe("test simple properties", async () => { it("page should have correct title", async () => { assert.strictEqual(await page.title(), "Food Journal"); }); }); describe("test CRUD on simple inputs and default image", () => { describe("test create 1 new review", async () => { it("create 1 new review", async () => { // Click the button to create a new review let create_btn = await page.$("#create-btn"); await create_btn.click(); await page.waitForNavigation(); // create a new review let review = { mealName: "sample name", comments: "sample comment", restaurant: "sample restaurant", tags: ["tag 0", "tag 1", "tag 2", "tag 3", "tag 4"], rating: 1, }; await setReviewForm(page, review); // Click the save button to save updates let save_btn = await page.$("#save-btn"); await save_btn.click(); await page.waitForNavigation(); }); it("check details page", async () => { // check the details page for correctness let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "sample name", comments: "sample comment", restaurant: "sample restaurant", tags: ["tag 0", "tag 1", "tag 2", "tag 3", "tag 4"], rating: "http://localhost:8080/assets/images/1-star.svg", }; await checkCorrectness(page, "d", expected); }); it("check home page", async () => { // Click the button to return to the home page let home_btn = await page.$("#home-btn"); home_btn.click(); await page.waitForNavigation(); // Get the review card again and get its shadowRoot let review_card = await page.$("review-card"); let shadowRoot = await review_card.getProperty("shadowRoot"); let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "sample name", comments: "sample comment", restaurant: "sample restaurant", tags: ["tag 0", "tag 1", "tag 2", "tag 3", "tag 4"], rating: "http://localhost:8080/assets/images/1-star.svg", }; await checkCorrectness(shadowRoot, "a", expected); }); }); describe("test read 1 review after refresh", async () => { it("refresh page", async () => { // Reload the page await page.reload({ waitUntil: ["networkidle0", "domcontentloaded"] }); }); it("check details page", async () => { // click review card let review_card = await page.$("review-card"); await review_card.click(); await page.waitForNavigation(); // check the details page for correctness let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "sample name", comments: "sample comment", restaurant: "sample restaurant", tags: ["tag 0", "tag 1", "tag 2", "tag 3", "tag 4"], rating: "http://localhost:8080/assets/images/1-star.svg", }; await checkCorrectness(page, "d", expected); }); it("check home page", async () => { // Click the button to return to the home page let home_btn = await page.$("#home-btn"); home_btn.click(); await page.waitForNavigation(); // Get the review card again and get its shadowRoot let review_card = await page.$("review-card"); let shadowRoot = await review_card.getProperty("shadowRoot"); // check the details page for correctness let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "sample name", comments: "sample comment", restaurant: "sample restaurant", tags: ["tag 0", "tag 1", "tag 2", "tag 3", "tag 4"], rating: "http://localhost:8080/assets/images/1-star.svg", }; await checkCorrectness(shadowRoot, "a", expected); }); }); describe("test update 1 review", async () => { it("update 1 review", async () => { // Get the only review card and click it let review_card = await page.$("review-card"); await review_card.click(); await page.waitForNavigation(); // Click the button to show update form let update_btn = await page.$("#update-btn"); await update_btn.click(); // create a new review let review = { mealName: "updated name", comments: "updated comment", restaurant: "updated restaurant", tags: ["tag -0", "tag -1", "tag -2", "tag -3", "tag -4", "tag -5"], rating: 5, }; await setReviewForm(page, review); // Click the save button to save updates let save_btn = await page.$("#save-btn"); await save_btn.click(); await page.waitForNavigation(); }).timeout(10000); it("check details page", async () => { // check the details page for correctness let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "updated name", comments: "updated comment", restaurant: "updated restaurant", tags: ["tag -0", "tag -1", "tag -2", "tag -3", "tag -4", "tag -5"], rating: "http://localhost:8080/assets/images/5-star.svg", }; await checkCorrectness(page, "d", expected); }); it("check home page", async () => { // Click the button to return to the home page let home_btn = await page.$("#home-btn"); home_btn.click(); await page.waitForNavigation(); // Get the review card again and get its shadowRoot let review_card = await page.$("review-card"); let shadowRoot = await review_card.getProperty("shadowRoot"); // check the details page for correctness let expected = { imgSrc: "http://localhost:8080/assets/images/default_plate.png", mealName: "updated name", comments: "updated comment", restaurant: "updated restaurant", tags: ["tag -0", "tag -1", "tag -2", "tag -3", "tag -4", "tag -5"], rating: "http://localhost:8080/assets/images/5-star.svg", }; await checkCorrectness(shadowRoot, "a", expected); }); }); describe("test delete 1 review", async () => { it("delete 1 review", async () => { // Get the only review card and click it let review_card = await page.$("review-card"); await review_card.click(); await page.waitForNavigation(); page.on("dialog", async (dialog) => { console.log(dialog.message()); await dialog.accept(); }); }); }); }); after(async () => { await page.close(); await browser.close(); }); });