fb3d262eb7
Fix badge navigation to use cluster-scoped path via Router.createRouteURL instead of hardcoded '/polaris'. Remove hardcoded RGB color assertions in badge color test. Scope ambiguous /%/ and 'Resources' selectors in polaris E2E tests. Fix settings tests to click into plugin settings before asserting. Fixes: PRI-151 Co-authored-by: gandalf-the-greybeard[bot] <gandalf-the-greybeard[bot]@users.noreply.github.com> Co-authored-by: Paperclip <noreply@paperclip.ing>
85 lines
3.0 KiB
TypeScript
85 lines
3.0 KiB
TypeScript
import { test, expect, Page } from '@playwright/test';
|
|
|
|
/** Navigate to the Polaris plugin settings page and wait for settings to render. */
|
|
async function goToPolarisSettings(page: Page) {
|
|
await page.goto('/c/main/settings/plugins');
|
|
|
|
// Find and click the Polaris plugin entry to open its settings
|
|
const pluginEntry = page.locator('text=polaris').first();
|
|
await expect(pluginEntry).toBeVisible({ timeout: 15_000 });
|
|
await pluginEntry.click();
|
|
|
|
// Wait for the PolarisSettings component to render
|
|
await expect(page.getByText('Polaris Settings')).toBeVisible({ timeout: 15_000 });
|
|
}
|
|
|
|
test.describe('Polaris plugin settings', () => {
|
|
test('settings page shows configuration options', async ({ page }) => {
|
|
await goToPolarisSettings(page);
|
|
|
|
// SectionBox title should be visible
|
|
await expect(page.getByText('Polaris Settings')).toBeVisible();
|
|
});
|
|
|
|
test('refresh interval setting is configurable', async ({ page }) => {
|
|
await goToPolarisSettings(page);
|
|
|
|
// Find the refresh interval dropdown
|
|
const intervalSelect = page.locator('select').filter({ hasText: /minute|second/ });
|
|
await expect(intervalSelect).toBeVisible();
|
|
|
|
// Get current value
|
|
const currentValue = await intervalSelect.inputValue();
|
|
|
|
// Change to a different value
|
|
const newValue = currentValue === '300' ? '600' : '300';
|
|
await intervalSelect.selectOption(newValue);
|
|
|
|
// Value should be updated
|
|
await expect(intervalSelect).toHaveValue(newValue);
|
|
});
|
|
|
|
test('dashboard URL setting is configurable', async ({ page }) => {
|
|
await goToPolarisSettings(page);
|
|
|
|
// Find the dashboard URL input
|
|
const urlInput = page.getByPlaceholder(/polaris-dashboard/);
|
|
await expect(urlInput).toBeVisible();
|
|
|
|
// Input should have the default proxy URL or custom URL
|
|
const currentUrl = await urlInput.inputValue();
|
|
expect(currentUrl).toBeTruthy();
|
|
|
|
// Examples text should be visible
|
|
await expect(page.getByText('Examples:')).toBeVisible();
|
|
await expect(page.getByText(/K8s proxy:/)).toBeVisible();
|
|
});
|
|
|
|
test('connection test button is available', async ({ page }) => {
|
|
await goToPolarisSettings(page);
|
|
|
|
// Find and verify test connection button
|
|
const testButton = page.getByRole('button', { name: /test connection/i });
|
|
await expect(testButton).toBeVisible();
|
|
await expect(testButton).toBeEnabled();
|
|
});
|
|
|
|
test('connection test works with valid URL', async ({ page }) => {
|
|
await goToPolarisSettings(page);
|
|
|
|
// Click test connection
|
|
const testButton = page.getByRole('button', { name: /test connection/i });
|
|
await testButton.click();
|
|
|
|
// Wait for either success or error message
|
|
// Note: This will succeed if Polaris is accessible, fail otherwise
|
|
await page.waitForSelector('text=/Connected successfully|Connection failed/', {
|
|
timeout: 15_000,
|
|
});
|
|
|
|
// Either success or failure is acceptable (depends on environment)
|
|
const result = await page.textContent('body');
|
|
expect(result).toMatch(/(Connected successfully|Connection failed)/);
|
|
});
|
|
});
|