| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- using NSubstitute;
- using RackPeek.Domain.Helpers;
- using RackPeek.Domain.Resources.Hardware;
- using RackPeek.Domain.Resources.Hardware.Servers.Nics;
- using RackPeek.Domain.Resources.Models;
- namespace Tests.HardwareResources;
- public class AddNicUseCaseTests
- {
- [Fact]
- public async Task ExecuteAsync_Adds_nic_when_server_exists()
- {
- var repo = Substitute.For<IHardwareRepository>();
- var server = new Server
- {
- Name = "node01",
- Nics = new List<Nic>()
- };
- repo.GetByNameAsync("node01").Returns(server);
- var sut = new AddNicUseCase(repo);
- await sut.ExecuteAsync("node01", "rj45", 10000, 2);
- Assert.Single(server.Nics);
- Assert.Equal("rj45", server.Nics[0].Type);
- Assert.Equal(10000, server.Nics[0].Speed!.Value);
- Assert.Equal(2, server.Nics[0].Ports!.Value);
- await repo.Received(1).UpdateAsync(Arg.Is<Server>(s =>
- s.Nics.Count == 1 &&
- s.Nics[0].Type == "rj45"
- ));
- }
- [Fact]
- public async Task ExecuteAsync_Initializes_list_when_null()
- {
- var repo = Substitute.For<IHardwareRepository>();
- var server = new Server { Name = "node01", Nics = null };
- repo.GetByNameAsync("node01").Returns(server);
- var sut = new AddNicUseCase(repo);
- await sut.ExecuteAsync("node01", "SFP+", 10000, 1);
- Assert.NotNull(server.Nics);
- Assert.Single(server.Nics);
- await repo.Received(1).UpdateAsync(Arg.Any<Server>());
- }
- [Fact]
- public async Task ExecuteAsync_throws_when_server_not_found()
- {
- var repo = Substitute.For<IHardwareRepository>();
- repo.GetByNameAsync("node01")
- .Returns((Hardware?)null);
- var sut = new AddNicUseCase(repo);
- var ex = await Assert.ThrowsAsync<NotFoundException>(async () =>
- await sut.ExecuteAsync("node01", "SFP+", 10000, 1)
- );
- // Assert
- await repo.DidNotReceive().UpdateAsync(Arg.Any<Server>());
- }
- }
|