2022-06-30 01:46:41 +02:00
|
|
|
|
using Bit.Core.Context;
|
2022-05-10 23:12:09 +02:00
|
|
|
|
using Bit.Core.Entities;
|
2022-07-18 02:24:46 +02:00
|
|
|
|
using Bit.Core.Entities.Provider;
|
2022-05-10 23:12:09 +02:00
|
|
|
|
using Bit.Core.Enums;
|
|
|
|
|
using Bit.Core.Models.Data;
|
2022-07-18 02:24:46 +02:00
|
|
|
|
using Bit.Core.Models.Data.Organizations;
|
2019-07-06 05:35:54 +02:00
|
|
|
|
using Bit.Core.Services;
|
2022-05-10 23:12:09 +02:00
|
|
|
|
using Bit.Test.Common.AutoFixture;
|
|
|
|
|
using Bit.Test.Common.AutoFixture.Attributes;
|
|
|
|
|
using Bit.Test.Common.Helpers;
|
2019-07-06 05:35:54 +02:00
|
|
|
|
using NSubstitute;
|
|
|
|
|
using Xunit;
|
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
namespace Bit.Core.Test.Services;
|
|
|
|
|
|
|
|
|
|
[SutProviderCustomize]
|
|
|
|
|
public class EventServiceTests
|
2019-07-06 05:35:54 +02:00
|
|
|
|
{
|
2022-08-29 22:06:55 +02:00
|
|
|
|
public static IEnumerable<object[]> InstallationIdTestCases => TestCaseHelper.GetCombinationsOfMultipleLists(
|
|
|
|
|
new object[] { Guid.NewGuid(), null },
|
|
|
|
|
Enum.GetValues<EventType>().Select(e => (object)e)
|
|
|
|
|
).Select(p => p.ToArray());
|
2022-08-29 21:53:48 +02:00
|
|
|
|
|
2022-11-09 13:13:29 +01:00
|
|
|
|
[Theory, BitAutoData]
|
|
|
|
|
public async Task LogGroupEvent_LogsRequiredInfo(Group group, EventType eventType, DateTime date,
|
2023-01-19 17:00:54 +01:00
|
|
|
|
Guid actingUserId, Guid providerId, string ipAddress, DeviceType deviceType, SutProvider<EventService> sutProvider)
|
2022-11-09 13:13:29 +01:00
|
|
|
|
{
|
|
|
|
|
var orgAbilities = new Dictionary<Guid, OrganizationAbility>()
|
|
|
|
|
{
|
|
|
|
|
{ group.OrganizationId, new OrganizationAbility() { UseEvents = true, Enabled = true } }
|
|
|
|
|
};
|
|
|
|
|
sutProvider.GetDependency<IApplicationCacheService>().GetOrganizationAbilitiesAsync().Returns(orgAbilities);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().UserId.Returns(actingUserId);
|
2023-01-19 17:00:54 +01:00
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().IpAddress.Returns(ipAddress);
|
2022-11-09 13:13:29 +01:00
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().DeviceType.Returns(deviceType);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().ProviderIdForOrg(Arg.Any<Guid>()).Returns(providerId);
|
|
|
|
|
|
|
|
|
|
await sutProvider.Sut.LogGroupEventAsync(group, eventType, date);
|
|
|
|
|
|
2023-01-19 17:00:54 +01:00
|
|
|
|
var expected = new List<IEvent>() {
|
|
|
|
|
new EventMessage()
|
|
|
|
|
{
|
|
|
|
|
IpAddress = ipAddress,
|
|
|
|
|
DeviceType = deviceType,
|
|
|
|
|
OrganizationId = group.OrganizationId,
|
|
|
|
|
GroupId = group.Id,
|
|
|
|
|
Type = eventType,
|
|
|
|
|
ActingUserId = actingUserId,
|
|
|
|
|
ProviderId = providerId,
|
|
|
|
|
Date = date,
|
|
|
|
|
SystemUser = null
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateManyAsync(Arg.Is(AssertHelper.AssertPropertyEqual<IEvent>(expected, new[] { "IdempotencyId" })));
|
2022-11-09 13:13:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
[Theory, BitAutoData]
|
|
|
|
|
public async Task LogGroupEvent_WithEventSystemUser_LogsRequiredInfo(Group group, EventType eventType, EventSystemUser eventSystemUser, DateTime date,
|
2023-01-19 17:00:54 +01:00
|
|
|
|
Guid actingUserId, Guid providerId, string ipAddress, DeviceType deviceType, SutProvider<EventService> sutProvider)
|
2022-11-09 13:13:29 +01:00
|
|
|
|
{
|
|
|
|
|
var orgAbilities = new Dictionary<Guid, OrganizationAbility>()
|
|
|
|
|
{
|
|
|
|
|
{ group.OrganizationId, new OrganizationAbility() { UseEvents = true, Enabled = true } }
|
|
|
|
|
};
|
|
|
|
|
sutProvider.GetDependency<IApplicationCacheService>().GetOrganizationAbilitiesAsync().Returns(orgAbilities);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().UserId.Returns(actingUserId);
|
2023-01-19 17:00:54 +01:00
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().IpAddress.Returns(ipAddress);
|
2022-11-09 13:13:29 +01:00
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().DeviceType.Returns(deviceType);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().ProviderIdForOrg(Arg.Any<Guid>()).Returns(providerId);
|
|
|
|
|
|
|
|
|
|
await sutProvider.Sut.LogGroupEventAsync(group, eventType, eventSystemUser, date);
|
|
|
|
|
|
2023-01-19 17:00:54 +01:00
|
|
|
|
var expected = new List<IEvent>() {
|
|
|
|
|
new EventMessage()
|
|
|
|
|
{
|
|
|
|
|
IpAddress = ipAddress,
|
|
|
|
|
DeviceType = deviceType,
|
|
|
|
|
OrganizationId = group.OrganizationId,
|
|
|
|
|
GroupId = group.Id,
|
|
|
|
|
Type = eventType,
|
|
|
|
|
ActingUserId = actingUserId,
|
|
|
|
|
ProviderId = providerId,
|
|
|
|
|
Date = date,
|
|
|
|
|
SystemUser = eventSystemUser
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateManyAsync(Arg.Is(AssertHelper.AssertPropertyEqual<IEvent>(expected, new[] { "IdempotencyId" })));
|
2022-11-09 13:13:29 +01:00
|
|
|
|
}
|
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
[Theory]
|
|
|
|
|
[BitMemberAutoData(nameof(InstallationIdTestCases))]
|
|
|
|
|
public async Task LogOrganizationEvent_ProvidesInstallationId(Guid? installationId, EventType eventType,
|
|
|
|
|
Organization organization, SutProvider<EventService> sutProvider)
|
|
|
|
|
{
|
|
|
|
|
organization.Enabled = true;
|
|
|
|
|
organization.UseEvents = true;
|
2019-07-06 05:35:54 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().InstallationId.Returns(installationId);
|
2019-07-06 05:35:54 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.Sut.LogOrganizationEventAsync(organization, eventType);
|
2022-05-10 23:12:09 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateAsync(Arg.Is<IEvent>(e =>
|
|
|
|
|
e.OrganizationId == organization.Id &&
|
|
|
|
|
e.Type == eventType &&
|
|
|
|
|
e.InstallationId == installationId));
|
|
|
|
|
}
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
[Theory, BitAutoData]
|
|
|
|
|
public async Task LogOrganizationUserEvent_LogsRequiredInfo(OrganizationUser orgUser, EventType eventType, DateTime date,
|
|
|
|
|
Guid actingUserId, Guid providerId, string ipAddress, DeviceType deviceType, SutProvider<EventService> sutProvider)
|
|
|
|
|
{
|
|
|
|
|
var orgAbilities = new Dictionary<Guid, OrganizationAbility>()
|
2022-07-18 02:24:46 +02:00
|
|
|
|
{
|
2022-08-29 22:06:55 +02:00
|
|
|
|
{orgUser.OrganizationId, new OrganizationAbility() { UseEvents = true, Enabled = true } }
|
|
|
|
|
};
|
|
|
|
|
sutProvider.GetDependency<IApplicationCacheService>().GetOrganizationAbilitiesAsync().Returns(orgAbilities);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().UserId.Returns(actingUserId);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().IpAddress.Returns(ipAddress);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().DeviceType.Returns(deviceType);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().ProviderIdForOrg(Arg.Any<Guid>()).Returns(providerId);
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.Sut.LogOrganizationUserEventAsync(orgUser, eventType, date);
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
var expected = new List<IEvent>() {
|
|
|
|
|
new EventMessage()
|
|
|
|
|
{
|
|
|
|
|
IpAddress = ipAddress,
|
|
|
|
|
DeviceType = deviceType,
|
|
|
|
|
OrganizationId = orgUser.OrganizationId,
|
|
|
|
|
UserId = orgUser.UserId,
|
|
|
|
|
OrganizationUserId = orgUser.Id,
|
|
|
|
|
ProviderId = providerId,
|
|
|
|
|
Type = eventType,
|
|
|
|
|
ActingUserId = actingUserId,
|
|
|
|
|
Date = date
|
|
|
|
|
}
|
|
|
|
|
};
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateManyAsync(Arg.Is(AssertHelper.AssertPropertyEqual<IEvent>(expected, new[] { "IdempotencyId" })));
|
|
|
|
|
}
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-11-09 13:13:29 +01:00
|
|
|
|
[Theory, BitAutoData]
|
|
|
|
|
public async Task LogOrganizationUserEvent_WithEventSystemUser_LogsRequiredInfo(OrganizationUser orgUser, EventType eventType, EventSystemUser eventSystemUser, DateTime date,
|
|
|
|
|
Guid actingUserId, Guid providerId, string ipAddress, DeviceType deviceType, SutProvider<EventService> sutProvider)
|
|
|
|
|
{
|
|
|
|
|
var orgAbilities = new Dictionary<Guid, OrganizationAbility>()
|
|
|
|
|
{
|
|
|
|
|
{orgUser.OrganizationId, new OrganizationAbility() { UseEvents = true, Enabled = true } }
|
|
|
|
|
};
|
|
|
|
|
sutProvider.GetDependency<IApplicationCacheService>().GetOrganizationAbilitiesAsync().Returns(orgAbilities);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().UserId.Returns(actingUserId);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().IpAddress.Returns(ipAddress);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().ProviderIdForOrg(Arg.Any<Guid>()).Returns(providerId);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().DeviceType.Returns(deviceType);
|
|
|
|
|
|
|
|
|
|
await sutProvider.Sut.LogOrganizationUserEventAsync(orgUser, eventType, eventSystemUser, date);
|
|
|
|
|
|
|
|
|
|
var expected = new List<IEvent>() {
|
|
|
|
|
new EventMessage()
|
|
|
|
|
{
|
|
|
|
|
IpAddress = ipAddress,
|
|
|
|
|
DeviceType = deviceType,
|
|
|
|
|
OrganizationId = orgUser.OrganizationId,
|
|
|
|
|
UserId = orgUser.UserId,
|
|
|
|
|
OrganizationUserId = orgUser.Id,
|
|
|
|
|
ProviderId = providerId,
|
|
|
|
|
Type = eventType,
|
|
|
|
|
ActingUserId = actingUserId,
|
|
|
|
|
Date = date,
|
|
|
|
|
SystemUser = eventSystemUser
|
|
|
|
|
}
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateManyAsync(Arg.Is(AssertHelper.AssertPropertyEqual<IEvent>(expected, new[] { "IdempotencyId" })));
|
|
|
|
|
}
|
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
[Theory, BitAutoData]
|
|
|
|
|
public async Task LogProviderUserEvent_LogsRequiredInfo(ProviderUser providerUser, EventType eventType, DateTime date,
|
|
|
|
|
Guid actingUserId, Guid providerId, string ipAddress, DeviceType deviceType, SutProvider<EventService> sutProvider)
|
|
|
|
|
{
|
|
|
|
|
var providerAbilities = new Dictionary<Guid, ProviderAbility>()
|
2022-07-18 02:24:46 +02:00
|
|
|
|
{
|
2022-08-29 22:06:55 +02:00
|
|
|
|
{providerUser.ProviderId, new ProviderAbility() { UseEvents = true, Enabled = true } }
|
|
|
|
|
};
|
|
|
|
|
sutProvider.GetDependency<IApplicationCacheService>().GetProviderAbilitiesAsync().Returns(providerAbilities);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().UserId.Returns(actingUserId);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().IpAddress.Returns(ipAddress);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().DeviceType.Returns(deviceType);
|
|
|
|
|
sutProvider.GetDependency<ICurrentContext>().ProviderIdForOrg(Arg.Any<Guid>()).Returns(providerId);
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.Sut.LogProviderUserEventAsync(providerUser, eventType, date);
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
var expected = new List<IEvent>() {
|
|
|
|
|
new EventMessage()
|
|
|
|
|
{
|
|
|
|
|
IpAddress = ipAddress,
|
|
|
|
|
DeviceType = deviceType,
|
|
|
|
|
ProviderId = providerUser.ProviderId,
|
|
|
|
|
UserId = providerUser.UserId,
|
|
|
|
|
ProviderUserId = providerUser.Id,
|
|
|
|
|
Type = eventType,
|
|
|
|
|
ActingUserId = actingUserId,
|
|
|
|
|
Date = date
|
|
|
|
|
}
|
|
|
|
|
};
|
2022-07-18 02:24:46 +02:00
|
|
|
|
|
2022-08-29 22:06:55 +02:00
|
|
|
|
await sutProvider.GetDependency<IEventWriteService>().Received(1).CreateManyAsync(Arg.Is(AssertHelper.AssertPropertyEqual<IEvent>(expected, new[] { "IdempotencyId" })));
|
2019-07-06 05:35:54 +02:00
|
|
|
|
}
|
|
|
|
|
}
|