Browse Source

E2E Access Point Tests

James 2 months ago
parent
commit
bf0f7ce586

+ 2 - 2
RackPeek/Commands/AccessPointReportCommand.cs

@@ -28,13 +28,13 @@ public class AccessPointReportCommand(
             .Border(TableBorder.Rounded)
             .AddColumn("Name")
             .AddColumn("Model")
-            .AddColumn("Speed (Gb)");
+            .AddColumn("Speed (Gbps)");
 
         foreach (var ap in report.AccessPoints)
             table.AddRow(
                 ap.Name,
                 ap.Model,
-                $"{ap.SpeedGb}G"
+                $"{ap.SpeedGb}"
             );
 
         AnsiConsole.Write(table);

+ 1 - 1
RackPeek/Commands/AccessPoints/AccessPointAddCommand.cs

@@ -25,7 +25,7 @@ public class AccessPointAddCommand(
 
         await useCase.ExecuteAsync(settings.Name);
 
-        AnsiConsole.MarkupLine($"[green]Access point '{settings.Name}' added.[/]");
+        AnsiConsole.MarkupLine($"[green]Access Point '{settings.Name}' added.[/]");
         return 0;
     }
 }

+ 1 - 1
RackPeek/Commands/AccessPoints/AccessPointDeleteCommand.cs

@@ -19,7 +19,7 @@ public class AccessPointDeleteCommand(
 
         await useCase.ExecuteAsync(settings.Name);
 
-        AnsiConsole.MarkupLine($"[green]Access point '{settings.Name}' deleted.[/]");
+        AnsiConsole.MarkupLine($"[green]Access Point '{settings.Name}' deleted.[/]");
         return 0;
     }
 }

+ 1 - 1
RackPeek/Commands/AccessPoints/AccessPointDescribeCommand.cs

@@ -21,7 +21,7 @@ public class AccessPointDescribeCommand(
 
         if (ap == null)
         {
-            AnsiConsole.MarkupLine($"[red]Access point '{settings.Name}' not found.[/]");
+            AnsiConsole.MarkupLine($"[red]Access Point '{settings.Name}' not found.[/]");
             return 1;
         }
 

+ 2 - 2
RackPeek/Commands/AccessPoints/AccessPointGetByNameCommand.cs

@@ -21,12 +21,12 @@ public class AccessPointGetByNameCommand(
 
         if (ap == null)
         {
-            AnsiConsole.MarkupLine($"[red]Access point '{settings.Name}' not found.[/]");
+            AnsiConsole.MarkupLine($"[red]Access Point '{settings.Name}' not found.[/]");
             return 1;
         }
 
         AnsiConsole.MarkupLine(
-            $"[green]{ap.Name}[/]  Model: {ap.Model ?? "Unknown"}, Speed: {(ap.Speed?.ToString() ?? "Unknown")} Gbps");
+            $"[green]{ap.Name}[/]  Model: {ap.Model ?? "Unknown"}, Speed: {(ap.Speed?.ToString() ?? "Unknown")}Gbps");
 
         return 0;
     }

+ 1 - 1
RackPeek/Commands/AccessPoints/AccessPointSetCommand.cs

@@ -33,7 +33,7 @@ public class AccessPointSetCommand(
             settings.Speed
         );
 
-        AnsiConsole.MarkupLine($"[green]Access point '{settings.Name}' updated.[/]");
+        AnsiConsole.MarkupLine($"[green]Access Point '{settings.Name}' updated.[/]");
         return 0;
     }
 }

+ 125 - 3
Tests/EndToEnd/AccessPointE2ETests.cs

@@ -1,6 +1,128 @@
+using Tests.EndToEnd.Infra;
+using Xunit.Abstractions;
+
 namespace Tests.EndToEnd;
 
-public class AccessPointE2ETests
+[Collection("Yaml CLI tests")]
+public class AccessPointYamlE2ETests(TempYamlCliFixture fs, ITestOutputHelper outputHelper)
+    : IClassFixture<TempYamlCliFixture>
 {
-    
-}
+    private async Task<(string, string)> ExecuteAsync(params string[] args)
+    {
+        outputHelper.WriteLine($"rpk {string.Join(" ", args)}");
+
+        var inputArgs = args.ToArray();
+        var output = await YamlCliTestHost.RunAsync(
+            inputArgs,
+            fs.Root,
+            outputHelper,
+            "config.yaml"
+        );
+
+        outputHelper.WriteLine(output);
+
+        var yaml = await File.ReadAllTextAsync(Path.Combine(fs.Root, "config.yaml"));
+        return (output, yaml);
+    }
+
+    [Fact]
+    public async Task accesspoints_cli_workflow_test()
+    {
+        await File.WriteAllTextAsync(Path.Combine(fs.Root, "config.yaml"), "");
+
+        // Add AP
+        var (output, yaml) = await ExecuteAsync("accesspoints", "add", "ap01");
+        Assert.Equal("Access Point 'ap01' added.\n", output);
+        Assert.Contains("name: ap01", yaml);
+
+        // Update AP
+        (output, yaml) = await ExecuteAsync(
+            "accesspoints", "set", "ap01",
+            "--model", "Unifi-U6-Lite",
+            "--speed", "1"
+        );
+        Assert.Equal("Access Point 'ap01' updated.\n", output);
+
+        Assert.Equal("""
+                     resources:
+                     - kind: AccessPoint
+                       model: Unifi-U6-Lite
+                       speed: 1
+                       name: ap01
+                       tags: 
+                     
+                     """, yaml);
+
+        // Add second AP
+        (output, yaml) = await ExecuteAsync("accesspoints", "add", "ap02");
+        Assert.Equal("Access Point 'ap02' added.\n", output);
+
+        (output, yaml) = await ExecuteAsync(
+            "accesspoints", "set", "ap02",
+            "--model", "Aruba-AP-515",
+            "--speed", "2.5"
+        );
+        Assert.Equal("Access Point 'ap02' updated.\n", output);
+
+        Assert.Equal("""
+                     resources:
+                     - kind: AccessPoint
+                       model: Unifi-U6-Lite
+                       speed: 1
+                       name: ap01
+                       tags: 
+                     - kind: AccessPoint
+                       model: Aruba-AP-515
+                       speed: 2.5
+                       name: ap02
+                       tags: 
+                     
+                     """, yaml);
+
+        // Get AP
+        (output, yaml) = await ExecuteAsync("accesspoints", "get", "ap01");
+        Assert.Equal("ap01  Model: Unifi-U6-Lite, Speed: 1Gbps\n", output);
+
+        // List APs
+        (output, yaml) = await ExecuteAsync("accesspoints", "list");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     │ ap02 │ Aruba-AP-515  │ 2.5          │
+                     ╰──────┴───────────────┴──────────────╯
+                     
+                     """, output);
+
+        // Summary
+        (output, yaml) = await ExecuteAsync("accesspoints", "summary");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     │ ap02 │ Aruba-AP-515  │ 2.5          │
+                     ╰──────┴───────────────┴──────────────╯
+                     
+                     """, output);
+
+        // Delete AP
+        (output, yaml) = await ExecuteAsync("accesspoints", "del", "ap02");
+        Assert.Equal("""
+                        Access Point 'ap02' deleted.
+                        
+                        """, output);
+
+        // List again
+        (output, yaml) = await ExecuteAsync("accesspoints", "list");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     ╰──────┴───────────────┴──────────────╯
+                     
+                     """, output);
+    }
+}