1
0
mirror of https://github.com/bitwarden/server.git synced 2024-12-04 14:13:28 +01:00
bitwarden-server/test/Core.Test/Services/AppleIapServiceTests.cs

41 lines
1.2 KiB
C#
Raw Normal View History

using Bit.Core.Services;
using Bit.Test.Common.AutoFixture;
using Bit.Test.Common.AutoFixture.Attributes;
using Microsoft.Extensions.Logging;
using NSubstitute;
using NSubstitute.Core;
using Xunit;
2022-08-29 22:06:55 +02:00
namespace Bit.Core.Test.Services;
[SutProviderCustomize]
public class AppleIapServiceTests
{
2022-08-29 22:06:55 +02:00
[Theory, BitAutoData]
public async Task GetReceiptStatusAsync_MoreThanFourAttempts_Throws(SutProvider<AppleIapService> sutProvider)
{
2022-08-29 22:06:55 +02:00
var result = await sutProvider.Sut.GetReceiptStatusAsync("test", false, 5, null);
Assert.Null(result);
2022-08-29 22:06:55 +02:00
var errorLog = sutProvider.GetDependency<ILogger<AppleIapService>>()
.ReceivedCalls()
.SingleOrDefault(LogOneWarning);
2022-08-29 22:06:55 +02:00
Assert.True(errorLog != null, "Must contain one error log of warning level containing 'null'");
2022-08-29 22:06:55 +02:00
static bool LogOneWarning(ICall call)
{
if (call.GetMethodInfo().Name != "Log")
{
2022-08-29 22:06:55 +02:00
return false;
}
2022-08-29 22:06:55 +02:00
var args = call.GetArguments();
var logLevel = (LogLevel)args[0];
var exception = (Exception)args[3];
2022-08-29 22:06:55 +02:00
return logLevel == LogLevel.Warning && exception.Message.Contains("null");
}
}
}