• fridendly-name.spec.js
  • import { expect, test } from "@playwright/test";
    import { login, restoreSqliteSnapshot, screenshot } from "../util-test";
    
    test.describe("Friendly Name Tests", () => {
        test.beforeEach(async ({ page }) => {
            await restoreSqliteSnapshot(page);
        });
    
        test("hostname", async ({ page }, testInfo) => {
            // Test DNS monitor with hostname
            await page.goto("./add");
            await login(page);
            await screenshot(testInfo, page);
    
            await page.getByTestId("monitor-type-select").selectOption("dns");
            await page.getByTestId("hostname-input").fill("example.com");
            await screenshot(testInfo, page);
    
            await page.getByTestId("save-button").click();
            await page.waitForURL("/dashboard/*");
    
            expect(page.getByTestId("monitor-list")).toContainText("example.com");
            await screenshot(testInfo, page);
        });
    
        test("URL hostname", async ({ page }, testInfo) => {
            // Test HTTP monitor with URL
            await page.goto("./add");
            await login(page);
            await screenshot(testInfo, page);
    
            await page.getByTestId("monitor-type-select").selectOption("http");
            await page.getByTestId("url-input").fill("https://www.example.com/");
            await screenshot(testInfo, page);
    
            await page.getByTestId("save-button").click();
            await page.waitForURL("/dashboard/*");
    
            expect(page.getByTestId("monitor-list")).toContainText("www.example.com");
            await screenshot(testInfo, page);
        });
    
        test("custom friendly name", async ({ page }, testInfo) => {
            // Test custom friendly name for HTTP monitor
            await page.goto("./add");
            await login(page);
            await screenshot(testInfo, page);
    
            await page.getByTestId("monitor-type-select").selectOption("http");
            await page.getByTestId("url-input").fill("https://www.example.com/");
    
            // Check if the friendly name placeholder is set to the hostname
            const friendlyNameInput = page.getByTestId("friendly-name-input");
            expect(friendlyNameInput).toHaveAttribute("placeholder", "www.example.com");
            await screenshot(testInfo, page);
    
            const customName = "Example Monitor";
            await friendlyNameInput.fill(customName);
            await screenshot(testInfo, page);
    
            await page.getByTestId("save-button").click();
            await page.waitForURL("/dashboard/*");
    
            expect(page.getByTestId("monitor-list")).toContainText(customName);
            await screenshot(testInfo, page);
        });
    
        test("default friendly name", async ({ page }, testInfo) => {
            // Test default friendly name when no custom name is provided
            await page.goto("./add");
            await login(page);
            await screenshot(testInfo, page);
    
            await page.getByTestId("monitor-type-select").selectOption("group");
            await screenshot(testInfo, page);
    
            await page.getByTestId("save-button").click();
            await page.waitForURL("/dashboard/*");
    
            expect(page.getByTestId("monitor-list")).toContainText("New Monitor");
            await screenshot(testInfo, page);
        });
    });