Explorar o código

Accesspoints Tests written

James hai 1 mes
pai
achega
bea9b8b116

+ 52 - 0
Tests/EndToEnd/AccessPointTests/AccessPointCommandTests.cs

@@ -0,0 +1,52 @@
+using Tests.EndToEnd.Infra;
+using Xunit.Abstractions;
+
+namespace Tests.EndToEnd;
+
+[Collection("Yaml CLI tests")]
+public class AccessPointCommandTests(TempYamlCliFixture fs, ITestOutputHelper outputHelper)
+    : IClassFixture<TempYamlCliFixture>
+{
+    private async Task<(string, string)> ExecuteAsync(params string[] args)
+    {
+        var output = await YamlCliTestHost.RunAsync(args, fs.Root, outputHelper, "config.yaml");
+
+        var yaml = await File.ReadAllTextAsync(Path.Combine(fs.Root, "config.yaml"));
+        return (output, yaml);
+    }
+
+    [Fact]
+    public async Task describe_returns_detailed_information()
+    {
+        // given
+        await ExecuteAsync("accesspoints", "add", "ap01");
+        await ExecuteAsync("accesspoints", "set", "ap01", "--model", "U6-Lite", "--speed", "1");
+
+        // when
+        var (output, _) = await ExecuteAsync("accesspoints", "describe", "ap01");
+
+        // then
+        Assert.Contains("Name:", output);
+        Assert.Contains("ap01", output);
+        Assert.Contains("Model:", output);
+        Assert.Contains("U6-Lite", output);
+        Assert.Contains("Speed (Gbps):", output);
+        Assert.Contains("1", output);
+    }
+
+    [Fact]
+    public async Task help_outputs_do_not_throw()
+    {
+        var (rootHelp, _) = await ExecuteAsync("accesspoints", "--help");
+        Assert.Contains("Manage access points", rootHelp);
+
+        var (addHelp, _) = await ExecuteAsync("accesspoints", "add", "--help");
+        Assert.Contains("Add a new access point", addHelp);
+
+        var (setHelp, _) = await ExecuteAsync("accesspoints", "set", "--help");
+        Assert.Contains("Update properties", setHelp);
+
+        var (describeHelp, _) = await ExecuteAsync("accesspoints", "describe", "--help");
+        Assert.Contains("Show detailed information", describeHelp);
+    }
+}

+ 72 - 0
Tests/EndToEnd/AccessPointTests/AccessPointErrorTests.cs

@@ -0,0 +1,72 @@
+using Tests.EndToEnd.Infra;
+using Xunit.Abstractions;
+
+namespace Tests.EndToEnd;
+
+[Collection("Yaml CLI tests")]
+public class AccessPointErrorTests(TempYamlCliFixture fs, ITestOutputHelper outputHelper)
+    : IClassFixture<TempYamlCliFixture>
+{
+    private async Task<(string, string)> ExecuteAsync(params string[] args)
+    {
+        var output = await YamlCliTestHost.RunAsync(
+            args,
+            fs.Root,
+            outputHelper,
+            "config.yaml");
+
+        var yaml = await File.ReadAllTextAsync(Path.Combine(fs.Root, "config.yaml"));
+        return (output, yaml);
+    }
+
+    [Fact]
+    public async Task adding_duplicate_access_point_returns_error()
+    {
+        await ExecuteAsync("accesspoints", "add", "ap01");
+
+        var (output, _) = await ExecuteAsync("accesspoints", "add", "ap01");
+
+        Assert.Contains("already exists", output, StringComparison.OrdinalIgnoreCase);
+    }
+
+    [Fact]
+    public async Task get_missing_access_point_returns_error()
+    {
+        var (output, _) = await ExecuteAsync("accesspoints", "get", "ghost");
+
+        Assert.Contains("not found", output, StringComparison.OrdinalIgnoreCase);
+    }
+
+    [Fact]
+    public async Task set_missing_access_point_returns_error()
+    {
+        var (output, _) = await ExecuteAsync(
+            "accesspoints", "set", "ghost",
+            "--model", "X",
+            "--speed", "1"
+        );
+
+        Assert.Contains("not found", output, StringComparison.OrdinalIgnoreCase);
+    }
+
+    [Fact]
+    public async Task delete_missing_access_point_returns_error()
+    {
+        var (output, _) = await ExecuteAsync("accesspoints", "del", "ghost");
+
+        Assert.Contains("not found", output, StringComparison.OrdinalIgnoreCase);
+    }
+
+    [Fact]
+    public async Task invalid_speed_value_returns_error()
+    {
+        await ExecuteAsync("accesspoints", "add", "ap01");
+
+        var (output, _) = await ExecuteAsync(
+            "accesspoints", "set", "ap01",
+            "--speed", "not-a-number"
+        );
+
+        Assert.Contains("invalid", output, StringComparison.OrdinalIgnoreCase);
+    }
+}

+ 113 - 0
Tests/EndToEnd/AccessPointTests/AccessPointWorkflowTests.cs

@@ -0,0 +1,113 @@
+using Tests.EndToEnd.Infra;
+using Xunit.Abstractions;
+
+namespace Tests.EndToEnd;
+
+[Collection("Yaml CLI tests")]
+public class AccessPointWorkflowTests(TempYamlCliFixture fs, ITestOutputHelper outputHelper)
+    : IClassFixture<TempYamlCliFixture>
+{
+    private async Task<(string, string)> ExecuteAsync(params string[] args)
+    {
+        outputHelper.WriteLine($"rpk {string.Join(" ", args)}");
+
+        var output = await YamlCliTestHost.RunAsync(
+            args,
+            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()
+    {
+        var (output, yaml) = await ExecuteAsync("accesspoints", "add", "ap01");
+        Assert.Equal("Access Point 'ap01' added.\n", output);
+        Assert.Contains("name: ap01", yaml);
+
+        (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
+
+                     """, yaml);
+
+        (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
+                     - kind: AccessPoint
+                       model: Aruba-AP-515
+                       speed: 2.5
+                       name: ap02
+
+                     """, yaml);
+
+        (output, yaml) = await ExecuteAsync("accesspoints", "get", "ap01");
+        Assert.Equal("ap01  Model: Unifi-U6-Lite, Speed: 1Gbps\n", output);
+
+        (output, yaml) = await ExecuteAsync("accesspoints", "list");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     │ ap02 │ Aruba-AP-515  │ 2.5          │
+                     ╰──────┴───────────────┴──────────────╯
+
+                     """, output);
+
+        (output, yaml) = await ExecuteAsync("accesspoints", "summary");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     │ ap02 │ Aruba-AP-515  │ 2.5          │
+                     ╰──────┴───────────────┴──────────────╯
+
+                     """, output);
+
+        (output, yaml) = await ExecuteAsync("accesspoints", "del", "ap02");
+        Assert.Equal("""
+                     Access Point 'ap02' deleted.
+
+                     """, output);
+
+        (output, yaml) = await ExecuteAsync("accesspoints", "list");
+        Assert.Equal("""
+                     ╭──────┬───────────────┬──────────────╮
+                     │ Name │ Model         │ Speed (Gbps) │
+                     ├──────┼───────────────┼──────────────┤
+                     │ ap01 │ Unifi-U6-Lite │ 1            │
+                     ╰──────┴───────────────┴──────────────╯
+
+                     """, output);
+    }
+}