| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132 |
- using Tests.EndToEnd.Infra;
- using Xunit.Abstractions;
- namespace Tests.EndToEnd.SwitchTests;
- [Collection("Yaml CLI tests")]
- public class SwitchWorkflowTests(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 switches_cli_workflow_test() {
- await File.WriteAllTextAsync(Path.Combine(fs.Root, "config.yaml"), "");
- // Add switch
- (var output, var yaml) = await ExecuteAsync("switches", "add", "sw01");
- Assert.Equal("Switch 'sw01' added.\n", output);
- Assert.Contains("name: sw01", yaml);
- // Update switch
- (output, yaml) = await ExecuteAsync(
- "switches", "set", "sw01",
- "--Model", "Netgear GS108",
- "--managed", "true",
- "--poe", "true"
- );
- // ToDo fails due command incorrect
- Assert.Equal("Switch 'sw01' updated.\n", output);
- Assert.Equal("""
- version: 3
- resources:
- - kind: Switch
- model: Netgear GS108
- managed: true
- poe: true
- name: sw01
- connections: []
- """, yaml);
- // Add second switch
- (output, yaml) = await ExecuteAsync("switches", "add", "sw02");
- Assert.Equal("Switch 'sw02' added.\n", output);
- (output, yaml) = await ExecuteAsync(
- "switches", "set", "sw02",
- "--Model", "TP-Link TL-SG108E",
- "--managed", "false",
- "--poe", "false"
- );
- // ToDo fails due command incorrect
- Assert.Equal("Switch 'sw02' updated.\n", output);
- Assert.Equal("""
- version: 3
- resources:
- - kind: Switch
- model: Netgear GS108
- managed: true
- poe: true
- name: sw01
- - kind: Switch
- model: TP-Link TL-SG108E
- managed: false
- poe: false
- name: sw02
- connections: []
- """, yaml);
- // Get switch
- (output, yaml) = await ExecuteAsync("switches", "get", "sw01");
- Assert.Equal("sw01 Model: Netgear GS108, Managed: Yes, PoE: Yes\n", output);
- // List switches
- (output, yaml) = await ExecuteAsync("switches", "list");
- Assert.Equal("""
- ╭──────┬───────────────────┬─────────┬─────┬───────┬──────────────╮
- │ Name │ Model │ Managed │ PoE │ Ports │ Port Summary │
- ├──────┼───────────────────┼─────────┼─────┼───────┼──────────────┤
- │ sw01 │ Netgear GS108 │ yes │ yes │ 0 │ Unknown │
- │ sw02 │ TP-Link TL-SG108E │ no │ no │ 0 │ Unknown │
- ╰──────┴───────────────────┴─────────┴─────┴───────┴──────────────╯
- """, output);
- // Summary
- (output, yaml) = await ExecuteAsync("switches", "summary");
- Assert.Equal("""
- ╭──────┬───────────────────┬─────────┬─────┬───────┬───────────┬──────────────╮
- │ Name │ Model │ Managed │ PoE │ Ports │ Max Speed │ Port Summary │
- ├──────┼───────────────────┼─────────┼─────┼───────┼───────────┼──────────────┤
- │ sw01 │ Netgear GS108 │ yes │ yes │ 0 │ 0G │ Unknown │
- │ sw02 │ TP-Link TL-SG108E │ no │ no │ 0 │ 0G │ Unknown │
- ╰──────┴───────────────────┴─────────┴─────┴───────┴───────────┴──────────────╯
- """, output);
- // Delete switch
- (output, yaml) = await ExecuteAsync("switches", "del", "sw02");
- Assert.Equal("""
- Switch 'sw02' deleted.
- """, output);
- // List again
- (output, yaml) = await ExecuteAsync("switches", "list");
- Assert.Equal("""
- ╭──────┬───────────────┬─────────┬─────┬───────┬──────────────╮
- │ Name │ Model │ Managed │ PoE │ Ports │ Port Summary │
- ├──────┼───────────────┼─────────┼─────┼───────┼──────────────┤
- │ sw01 │ Netgear GS108 │ yes │ yes │ 0 │ Unknown │
- ╰──────┴───────────────┴─────────┴─────┴───────┴──────────────╯
- """, output);
- }
- }
|