7b0b9c7365
Solution + 23 src projects + 26 test projects renamed; folders, csproj, namespaces, and ScadaLinkDbContext/ScadaBridgeDbContext class updated. ActorSystem "scadalink" → "scadabridge", Akka seed-node URLs migrated. SQL roles/logins, LDAP domains, CLI command name, and CLI config dir (~/.scadalink → ~/.scadabridge) also renamed. Build green; 5 Host.Tests fail awaiting SQL login rename in next commit. Pre-existing StaleTagMonitor timing flakes unchanged. Rename script committed at tools/rename-to-scadabridge.sh.
90 lines
3.5 KiB
C#
90 lines
3.5 KiB
C#
using Microsoft.Playwright;
|
|
|
|
namespace ZB.MOM.WW.ScadaBridge.CentralUI.PlaywrightTests;
|
|
|
|
[Collection("Playwright")]
|
|
public class NavigationTests
|
|
{
|
|
private readonly PlaywrightFixture _fixture;
|
|
|
|
public NavigationTests(PlaywrightFixture fixture)
|
|
{
|
|
_fixture = fixture;
|
|
}
|
|
|
|
[Fact]
|
|
public async Task Dashboard_IsVisibleAfterLogin()
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
|
|
// The nav sidebar should be visible with the brand. ToContainText, not
|
|
// ToHaveText: the brand also carries the accent mark glyph (▮).
|
|
await Expect(page.Locator(".brand")).ToContainTextAsync("ScadaBridge");
|
|
// The nav should contain "Dashboard" link (exact match to avoid "Health Dashboard")
|
|
await Expect(page.GetByRole(AriaRole.Link, new() { Name = "Dashboard", Exact = true })).ToBeVisibleAsync();
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Sites", "/admin/sites")]
|
|
[InlineData("API Keys", "/admin/api-keys")]
|
|
[InlineData("LDAP Mappings", "/admin/ldap-mappings")]
|
|
public async Task AdminNavLinks_NavigateCorrectly(string linkText, string expectedPath)
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
await ClickNavAndWait(page, linkText, expectedPath);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("SMTP Configuration", "/notifications/smtp")]
|
|
[InlineData("Notification Lists", "/notifications/lists")]
|
|
[InlineData("Notification Report", "/notifications/report")]
|
|
[InlineData("Notification KPIs", "/notifications/kpis")]
|
|
public async Task NotificationsNavLinks_NavigateCorrectly(string linkText, string expectedPath)
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
await ClickNavAndWait(page, linkText, expectedPath);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Templates", "/design/templates")]
|
|
[InlineData("Shared Scripts", "/design/shared-scripts")]
|
|
[InlineData("Connections", "/design/connections")]
|
|
[InlineData("External Systems", "/design/external-systems")]
|
|
public async Task DesignNavLinks_NavigateCorrectly(string linkText, string expectedPath)
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
await ClickNavAndWait(page, linkText, expectedPath);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Topology", "/deployment/topology")]
|
|
[InlineData("Deployments", "/deployment/deployments")]
|
|
public async Task DeploymentNavLinks_NavigateCorrectly(string linkText, string expectedPath)
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
await ClickNavAndWait(page, linkText, expectedPath);
|
|
}
|
|
|
|
[Theory]
|
|
[InlineData("Health Dashboard", "/monitoring/health")]
|
|
[InlineData("Event Logs", "/monitoring/event-logs")]
|
|
[InlineData("Parked Messages", "/monitoring/parked-messages")]
|
|
public async Task MonitoringNavLinks_NavigateCorrectly(string linkText, string expectedPath)
|
|
{
|
|
var page = await _fixture.NewAuthenticatedPageAsync();
|
|
await ClickNavAndWait(page, linkText, expectedPath);
|
|
}
|
|
|
|
private static async Task ClickNavAndWait(IPage page, string linkText, string expectedPath)
|
|
{
|
|
// Sections are collapsed by default — open them so the link is in the DOM.
|
|
await PlaywrightFixture.ExpandAllNavSectionsAsync(page);
|
|
await page.Locator($"nav a:has-text('{linkText}')").ClickAsync();
|
|
await PlaywrightFixture.WaitForPathAsync(page, expectedPath);
|
|
Assert.Contains(expectedPath, page.Url);
|
|
}
|
|
|
|
private static ILocatorAssertions Expect(ILocator locator) =>
|
|
Assertions.Expect(locator);
|
|
}
|