You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
195 lines
8.6 KiB
195 lines
8.6 KiB
using System.Text.Json; |
|
using Bit.Core.Entities; |
|
using Bit.Core.Entities.Provider; |
|
using Bit.Core.Enums; |
|
using Bit.Core.Models.Data; |
|
using Bit.Core.Repositories; |
|
using Bit.Core.Test.AutoFixture.Attributes; |
|
using Bit.Infrastructure.EFIntegration.Test.AutoFixture; |
|
using Bit.Infrastructure.EFIntegration.Test.Repositories.EqualityComparers; |
|
using Xunit; |
|
using EfRepo = Bit.Infrastructure.EntityFramework.Repositories; |
|
using Policy = Bit.Core.Entities.Policy; |
|
using SqlRepo = Bit.Infrastructure.Dapper.Repositories; |
|
|
|
namespace Bit.Infrastructure.EFIntegration.Test.Repositories; |
|
|
|
public class PolicyRepositoryTests |
|
{ |
|
[CiSkippedTheory, EfPolicyAutoData] |
|
public async void CreateAsync_Works_DataMatches( |
|
Policy policy, |
|
Organization organization, |
|
PolicyCompare equalityComparer, |
|
List<EfRepo.PolicyRepository> suts, |
|
List<EfRepo.OrganizationRepository> efOrganizationRepos, |
|
SqlRepo.PolicyRepository sqlPolicyRepo, |
|
SqlRepo.OrganizationRepository sqlOrganizationRepo |
|
) |
|
{ |
|
var savedPolicys = new List<Policy>(); |
|
foreach (var sut in suts) |
|
{ |
|
var i = suts.IndexOf(sut); |
|
|
|
var efOrganization = await efOrganizationRepos[i].CreateAsync(organization); |
|
sut.ClearChangeTracking(); |
|
|
|
policy.OrganizationId = efOrganization.Id; |
|
var postEfPolicy = await sut.CreateAsync(policy); |
|
sut.ClearChangeTracking(); |
|
|
|
var savedPolicy = await sut.GetByIdAsync(postEfPolicy.Id); |
|
savedPolicys.Add(savedPolicy); |
|
} |
|
|
|
var sqlOrganization = await sqlOrganizationRepo.CreateAsync(organization); |
|
|
|
policy.OrganizationId = sqlOrganization.Id; |
|
var sqlPolicy = await sqlPolicyRepo.CreateAsync(policy); |
|
var savedSqlPolicy = await sqlPolicyRepo.GetByIdAsync(sqlPolicy.Id); |
|
savedPolicys.Add(savedSqlPolicy); |
|
|
|
var distinctItems = savedPolicys.Distinct(equalityComparer); |
|
Assert.True(!distinctItems.Skip(1).Any()); |
|
} |
|
|
|
[CiSkippedTheory] |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Confirmed, false, true, true, false)] // Ordinary user |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Invited, true, true, true, false)] // Invited user |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.Owner, false, OrganizationUserStatusType.Confirmed, false, true, true, false)] // Owner |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.Admin, false, OrganizationUserStatusType.Confirmed, false, true, true, false)] // Admin |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, true, OrganizationUserStatusType.Confirmed, false, true, true, false)] // canManagePolicies |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Confirmed, false, true, true, true)] // Provider |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Confirmed, false, false, true, false)] // Policy disabled |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Confirmed, false, true, false, false)] // No policy of Type |
|
[EfPolicyApplicableToUserInlineAutoData(OrganizationUserType.User, false, OrganizationUserStatusType.Invited, false, true, true, false)] // User not minStatus |
|
|
|
public async void GetManyByTypeApplicableToUser_Works_DataMatches( |
|
// Inline data |
|
OrganizationUserType userType, |
|
bool canManagePolicies, |
|
OrganizationUserStatusType orgUserStatus, |
|
bool includeInvited, |
|
bool policyEnabled, |
|
bool policySameType, |
|
bool isProvider, |
|
|
|
// Auto data - models |
|
Policy policy, |
|
User user, |
|
Organization organization, |
|
OrganizationUser orgUser, |
|
Provider provider, |
|
ProviderOrganization providerOrganization, |
|
ProviderUser providerUser, |
|
PolicyCompareIncludingOrganization equalityComparer, |
|
|
|
// Auto data - EF repos |
|
List<EfRepo.PolicyRepository> suts, |
|
List<EfRepo.UserRepository> efUserRepository, |
|
List<EfRepo.OrganizationRepository> efOrganizationRepository, |
|
List<EfRepo.OrganizationUserRepository> efOrganizationUserRepository, |
|
List<EfRepo.ProviderRepository> efProviderRepository, |
|
List<EfRepo.ProviderOrganizationRepository> efProviderOrganizationRepository, |
|
List<EfRepo.ProviderUserRepository> efProviderUserRepository, |
|
|
|
// Auto data - SQL repos |
|
SqlRepo.PolicyRepository sqlPolicyRepo, |
|
SqlRepo.UserRepository sqlUserRepo, |
|
SqlRepo.OrganizationRepository sqlOrganizationRepo, |
|
SqlRepo.ProviderRepository sqlProviderRepo, |
|
SqlRepo.OrganizationUserRepository sqlOrganizationUserRepo, |
|
SqlRepo.ProviderOrganizationRepository sqlProviderOrganizationRepo, |
|
SqlRepo.ProviderUserRepository sqlProviderUserRepo |
|
) |
|
{ |
|
// Combine EF and SQL repos into one list per type |
|
var policyRepos = suts.ToList<IPolicyRepository>(); |
|
policyRepos.Add(sqlPolicyRepo); |
|
var userRepos = efUserRepository.ToList<IUserRepository>(); |
|
userRepos.Add(sqlUserRepo); |
|
var orgRepos = efOrganizationRepository.ToList<IOrganizationRepository>(); |
|
orgRepos.Add(sqlOrganizationRepo); |
|
var orgUserRepos = efOrganizationUserRepository.ToList<IOrganizationUserRepository>(); |
|
orgUserRepos.Add(sqlOrganizationUserRepo); |
|
var providerRepos = efProviderRepository.ToList<IProviderRepository>(); |
|
providerRepos.Add(sqlProviderRepo); |
|
var providerOrgRepos = efProviderOrganizationRepository.ToList<IProviderOrganizationRepository>(); |
|
providerOrgRepos.Add(sqlProviderOrganizationRepo); |
|
var providerUserRepos = efProviderUserRepository.ToList<IProviderUserRepository>(); |
|
providerUserRepos.Add(sqlProviderUserRepo); |
|
|
|
// Arrange data |
|
var savedPolicyType = PolicyType.SingleOrg; |
|
var queriedPolicyType = policySameType ? savedPolicyType : PolicyType.DisableSend; |
|
|
|
orgUser.Type = userType; |
|
orgUser.Status = orgUserStatus; |
|
var permissionsData = new Permissions { ManagePolicies = canManagePolicies }; |
|
orgUser.Permissions = JsonSerializer.Serialize(permissionsData, new JsonSerializerOptions |
|
{ |
|
PropertyNamingPolicy = JsonNamingPolicy.CamelCase, |
|
}); |
|
|
|
policy.Enabled = policyEnabled; |
|
policy.Type = savedPolicyType; |
|
|
|
var results = new List<Policy>(); |
|
|
|
foreach (var policyRepo in policyRepos) |
|
{ |
|
var i = policyRepos.IndexOf(policyRepo); |
|
|
|
// Seed database |
|
var savedUser = await userRepos[i].CreateAsync(user); |
|
var savedOrg = await orgRepos[i].CreateAsync(organization); |
|
|
|
// Invited orgUsers are not associated with an account yet, so they are identified by Email not UserId |
|
if (orgUserStatus == OrganizationUserStatusType.Invited) |
|
{ |
|
orgUser.Email = savedUser.Email; |
|
orgUser.UserId = null; |
|
} |
|
else |
|
{ |
|
orgUser.UserId = savedUser.Id; |
|
} |
|
|
|
orgUser.OrganizationId = savedOrg.Id; |
|
await orgUserRepos[i].CreateAsync(orgUser); |
|
|
|
if (isProvider) |
|
{ |
|
var savedProvider = await providerRepos[i].CreateAsync(provider); |
|
|
|
providerOrganization.OrganizationId = savedOrg.Id; |
|
providerOrganization.ProviderId = savedProvider.Id; |
|
await providerOrgRepos[i].CreateAsync(providerOrganization); |
|
|
|
providerUser.UserId = savedUser.Id; |
|
providerUser.ProviderId = savedProvider.Id; |
|
await providerUserRepos[i].CreateAsync(providerUser); |
|
} |
|
|
|
policy.OrganizationId = savedOrg.Id; |
|
await policyRepo.CreateAsync(policy); |
|
if (suts.Contains(policyRepo)) |
|
{ |
|
(policyRepo as EfRepo.BaseEntityFrameworkRepository).ClearChangeTracking(); |
|
} |
|
|
|
var minStatus = includeInvited ? OrganizationUserStatusType.Invited : OrganizationUserStatusType.Accepted; |
|
|
|
// Act |
|
var result = await policyRepo.GetManyByTypeApplicableToUserIdAsync(savedUser.Id, queriedPolicyType, minStatus); |
|
results.Add(result.FirstOrDefault()); |
|
} |
|
|
|
// Assert |
|
var distinctItems = results.Distinct(equalityComparer); |
|
|
|
Assert.True(results.All(r => r == null) || |
|
!distinctItems.Skip(1).Any()); |
|
} |
|
}
|
|
|