dioxus/packages/playwright-tests/liveview.spec.js
2024-01-30 18:51:19 -08:00

72 lines
2.4 KiB
JavaScript

// @ts-check
const { test, expect } = require('@playwright/test');
test('button click', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the counter text.
const main = page.locator('#main');
await expect(main).toContainText('hello axum! 0');
// Click the increment button.
await page.getByRole('button', { name: 'Increment' }).click();
// Expect the page to contain the updated counter text.
await expect(main).toContainText('hello axum! 1');
});
test('svg', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the svg.
const svg = page.locator('svg');
// Expect the svg to contain the circle.
const circle = svg.locator('circle');
await expect(circle).toHaveAttribute('cx', '50');
await expect(circle).toHaveAttribute('cy', '50');
await expect(circle).toHaveAttribute('r', '40');
await expect(circle).toHaveAttribute('stroke', 'green');
await expect(circle).toHaveAttribute('fill', 'yellow');
});
test('raw attribute', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the div with the raw attribute.
const div = page.locator('div.raw-attribute-div');
await expect(div).toHaveAttribute('raw-attribute', 'raw-attribute-value');
});
test('hidden attribute', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the div with the hidden attribute.
const div = page.locator('div.hidden-attribute-div');
await expect(div).toHaveAttribute('hidden', 'true');
});
test('dangerous inner html', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the div with the dangerous inner html.
const div = page.locator('div.dangerous-inner-html-div');
await expect(div).toContainText('hello dangerous inner html');
});
test('input value', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the input with the value.
const input = page.locator('input');
await expect(input).toHaveValue('hello input');
});
test('style', async ({ page }) => {
await page.goto('http://127.0.0.1:3030');
// Expect the page to contain the div with the style.
const div = page.locator('div.style-div');
await expect(div).toHaveText('colored text');
await expect(div).toHaveCSS('color', 'rgb(255, 0, 0)');
});