| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176 |
- using Microsoft.Playwright;
- using Tests.E2e.Infra;
- using Tests.E2e.PageObjectModels;
- using Xunit.Abstractions;
- namespace Tests.E2e;
- public class UpsCardTests(
- PlaywrightFixture fixture,
- ITestOutputHelper output) : E2ETestBase(fixture, output)
- {
- private readonly ITestOutputHelper _output = output;
- // =============================================================
- // Rename + Clone + Delete Flow
- // =============================================================
- [Fact]
- public async Task User_Can_Rename_Clone_And_Delete_Ups_From_Details_Page()
- {
- var (context, page) = await CreatePageAsync();
- var originalName = $"e2e-ups-{Guid.NewGuid():N}"[..16];
- var renamedName = $"e2e-ups-rn-{Guid.NewGuid():N}"[..16];
- var cloneName = $"e2e-ups-cl-{Guid.NewGuid():N}"[..16];
- try
- {
- await page.GotoAsync($"{fixture.BaseUrl}/ups/list");
- var list = new UpsListPom(page);
- await list.AddUpsAsync(originalName);
- if (!page.Url.Contains($"/resources/hardware/{originalName}",
- StringComparison.OrdinalIgnoreCase))
- {
- await list.OpenUpsAsync(originalName);
- }
- var card = new UpsCardPom(page);
- await card.AssertVisibleAsync(originalName);
- // -------------------------
- // Rename
- // -------------------------
- await card.RenameAsync(originalName, renamedName);
- await card.AssertVisibleAsync(renamedName);
- // -------------------------
- // Clone
- // -------------------------
- await card.CloneAsync(renamedName, cloneName);
- await card.AssertVisibleAsync(cloneName);
- // -------------------------
- // Delete clone
- // -------------------------
- await card.DeleteAsync(cloneName);
- await page.WaitForURLAsync("**/hardware/tree");
- // Navigate back and delete renamed
- await page.GotoAsync($"{fixture.BaseUrl}/resources/hardware/{renamedName}");
- await card.AssertVisibleAsync(renamedName);
- await card.DeleteAsync(renamedName);
- await page.WaitForURLAsync("**/hardware/tree");
- }
- catch (Exception)
- {
- _output.WriteLine("TEST FAILED — Capturing diagnostics");
- _output.WriteLine($"Current URL: {page.Url}");
- var html = await page.ContentAsync();
- _output.WriteLine("==== DOM SNAPSHOT START ====");
- _output.WriteLine(html);
- _output.WriteLine("==== DOM SNAPSHOT END ====");
- throw;
- }
- finally
- {
- await context.CloseAsync();
- }
- }
- // =============================================================
- // Edit + Save Flow
- // =============================================================
- [Fact]
- public async Task User_Can_Edit_And_Save_Ups()
- {
- var (context, page) = await CreatePageAsync();
- var name = $"e2e-ups-edit-{Guid.NewGuid():N}"[..16];
- try
- {
- await page.GotoAsync($"{fixture.BaseUrl}/ups/list");
- var list = new UpsListPom(page);
- await list.AddUpsAsync(name);
- if (!page.Url.Contains($"/resources/hardware/{name}",
- StringComparison.OrdinalIgnoreCase))
- {
- await list.OpenUpsAsync(name);
- }
- var card = new UpsCardPom(page);
- await card.AssertVisibleAsync(name);
- await card.BeginEditAsync(name);
- await card.ModelInput(name).FillAsync("APC Smart-UPS");
- await card.CapacityInput(name).FillAsync("1500");
- await card.SaveAsync(name);
- await Assertions.Expect(
- card.ModelValue(name)
- ).ToContainTextAsync("APC Smart-UPS");
- await Assertions.Expect(
- card.CapacityValue(name)
- ).ToContainTextAsync("1500");
- }
- finally
- {
- await context.CloseAsync();
- }
- }
- // =============================================================
- // Cancel Edit Flow
- // =============================================================
- [Fact]
- public async Task User_Can_Cancel_Ups_Edit_Without_Saving()
- {
- var (context, page) = await CreatePageAsync();
- var name = $"e2e-ups-cancel-{Guid.NewGuid():N}"[..16];
- try
- {
- await page.GotoAsync($"{fixture.BaseUrl}/ups/list");
- var list = new UpsListPom(page);
- await list.AddUpsAsync(name);
- if (!page.Url.Contains($"/resources/hardware/{name}",
- StringComparison.OrdinalIgnoreCase))
- {
- await list.OpenUpsAsync(name);
- }
- var card = new UpsCardPom(page);
- await card.AssertVisibleAsync(name);
- await card.BeginEditAsync(name);
- await card.ModelInput(name).FillAsync("ShouldNotPersist");
- await card.CapacityInput(name).FillAsync("9999");
- await card.CancelAsync(name);
- // Verify edit mode exited
- await Assertions.Expect(
- card.EditButton(name)
- ).ToBeVisibleAsync();
- }
- finally
- {
- await context.CloseAsync();
- }
- }
- }
|