Files
caddy-proxy-manager/tests/e2e/settings.spec.ts
fuomag9 2c70f2859a Add multi-provider DNS registry for ACME DNS-01 challenges
Replace hardcoded Cloudflare DNS-01 with a data-driven provider registry
supporting 11 providers (Cloudflare, Route 53, DigitalOcean, Duck DNS,
Hetzner, Vultr, Porkbun, GoDaddy, Namecheap, OVH, Linode). Users can
configure multiple providers with encrypted credentials and select a
default. Per-certificate provider override is supported via providerOptions.

- Add src/lib/dns-providers.ts with provider definitions, credential
  encrypt/decrypt, and Caddy config builder
- Change DnsProviderSettings to multi-provider format with default selection
- Auto-migrate legacy Cloudflare settings on startup (db.ts)
- Normalize old single-provider format on read (getDnsProviderSettings)
- Refactor buildTlsAutomation() to use provider registry
- Add GET /api/v1/dns-providers endpoint for provider discovery
- Add dns-provider settings group to REST API and instance sync
- Replace Cloudflare settings card with multi-provider UI (add/remove
  providers, set default, dynamic credential forms)
- Add 10 DNS provider modules to Caddy Dockerfile
- Update OpenAPI spec, E2E tests, and unit test mocks

Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
2026-04-17 18:01:16 +02:00

39 lines
1.5 KiB
TypeScript

import { test, expect } from '@playwright/test';
test.describe('Settings', () => {
test('settings page loads without redirecting to login', async ({ page }) => {
await page.goto('/settings');
await expect(page).not.toHaveURL(/login/);
await expect(page.locator('body')).toBeVisible();
});
test('settings page renders content', async ({ page }) => {
await page.goto('/settings');
const hasContent = await page.locator('text=/settings|general|dns provider|dns|logging/i').count() > 0;
expect(hasContent).toBe(true);
});
test('settings page has named save buttons', async ({ page }) => {
await page.goto('/settings');
await expect(page.getByRole('button', { name: /save general settings/i })).toBeVisible();
});
test('general settings: fill primary domain and save', async ({ page }) => {
await page.goto('/settings');
const domainInput = page.getByLabel('Primary domain');
await domainInput.fill('test.local');
await page.getByRole('button', { name: /save general settings/i }).click();
// Wait for the button to re-enable (save completes) or any success indicator
await expect(page.getByRole('button', { name: /save general settings/i })).toBeEnabled({ timeout: 10000 });
});
test('settings page has DNS Provider and DNS sections', async ({ page }) => {
await page.goto('/settings');
await expect(page.getByRole('heading', { name: 'DNS Providers' })).toBeVisible();
await expect(page.getByRole('button', { name: /save dns settings/i })).toBeVisible();
});
});