public async Task TryAddAsync_ShouldLogException_WhenLoggerIsGiven_AndTapThrowsException() { // Arrange var entity = new FakeEntity <int> { Id = 7, Name = "Tiffany" }; var expectedResult = true; _mockInner .Setup(u => u.TryAddAsync(entity)) .ReturnsAsync(expectedResult); _mockTap .Setup(u => u.AddOrUpdateAsync(entity)) .ThrowsAsync(new InvalidOperationException()); _mockLogger.Setup(l => l.Log(LogLevel.Warning, 0, It.IsAny <object>(), It.IsAny <InvalidOperationException>(), It.IsAny <Func <object, Exception, string> >())); var subject = new AsyncRepositoryTap <FakeEntity <int>, int>(_mockInner.Object, _mockTap.Object, _mockLogger.Object); // Act var actualResult = await subject.TryAddAsync(entity).ConfigureAwait(false); // Assert actualResult.Should().Be(expectedResult); _mockInner.VerifyAll(); _mockTap.VerifyAll(); _mockLogger.VerifyAll(); }
public async Task TryAddAsync_ShouldCallInner_AndTap_WhenLoggerIsGiven() { // Arrange var entity = new FakeEntity <int> { Id = 7, Name = "Tiffany" }; var expectedResult = true; _mockInner .Setup(r => r.TryAddAsync(entity)) .ReturnsAsync(expectedResult); _mockTap .Setup(r => r.AddOrUpdateAsync(entity)) .Returns(TaskHelpers.CompletedTask); var subject = new AsyncRepositoryTap <FakeEntity <int>, int>(_mockInner.Object, _mockTap.Object, _mockLogger.Object); // Act var actualResult = await subject.TryAddAsync(entity).ConfigureAwait(false); // Assert actualResult.Should().Be(expectedResult); _mockInner.VerifyAll(); _mockTap.VerifyAll(); _mockLogger.VerifyAll(); }
public async Task TryAddAsync_ShouldDoNothing_WhenTapThrowsException() { // Arrange var entity = new FakeEntity <int> { Id = 7, Name = "Tiffany" }; var expectedResult = true; _mockInner .Setup(u => u.TryAddAsync(entity)) .ReturnsAsync(expectedResult); _mockTap .Setup(u => u.AddOrUpdateAsync(entity)) .ThrowsAsync(new InvalidOperationException()); var subject = new AsyncRepositoryTap <FakeEntity <int>, int>(_mockInner.Object, _mockTap.Object); // Act var actualResult = await subject.TryAddAsync(entity).ConfigureAwait(false); // Assert actualResult.Should().Be(expectedResult); _mockInner.VerifyAll(); _mockTap.VerifyAll(); _mockLogger.VerifyAll(); }
public void TryAddAsync_ShouldSkipTap_WhenLoggerIsGiven_AndInnerThrowsException() { // Arrange var entity = new FakeEntity <int> { Id = 7, Name = "Tiffany" }; _mockInner .Setup(r => r.TryAddAsync(entity)) .ThrowsAsync(new InvalidOperationException()); var subject = new AsyncRepositoryTap <FakeEntity <int>, int>(_mockInner.Object, _mockTap.Object, _mockLogger.Object); // Act Func <Task> action = async() => await subject.TryAddAsync(entity).ConfigureAwait(false); // Assert action.Should().Throw <InvalidOperationException>(); _mockInner.VerifyAll(); _mockTap.VerifyAll(); _mockTap.VerifyAll(); }