mirror of
https://github.com/bitwarden/server.git
synced 2025-01-06 19:28:08 +01:00
bae03feffe
* Revert "Add git blame entry (#2226)" This reverts commit239286737d
. * Revert "Turn on file scoped namespaces (#2225)" This reverts commit34fb4cca2a
.
151 lines
6.7 KiB
C#
151 lines
6.7 KiB
C#
using Bit.Core.Models.Data.Organizations;
|
|
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 Organization = Bit.Core.Entities.Organization;
|
|
using SqlRepo = Bit.Infrastructure.Dapper.Repositories;
|
|
|
|
namespace Bit.Infrastructure.EFIntegration.Test.Repositories
|
|
{
|
|
public class OrganizationRepositoryTests
|
|
{
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void CreateAsync_Works_DataMatches(
|
|
Organization organization,
|
|
SqlRepo.OrganizationRepository sqlOrganizationRepo, OrganizationCompare equalityComparer,
|
|
List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
var savedOrganizations = new List<Organization>();
|
|
foreach (var sut in suts)
|
|
{
|
|
var postEfOrganization = await sut.CreateAsync(organization);
|
|
sut.ClearChangeTracking();
|
|
|
|
var savedOrganization = await sut.GetByIdAsync(organization.Id);
|
|
savedOrganizations.Add(savedOrganization);
|
|
}
|
|
|
|
var sqlOrganization = await sqlOrganizationRepo.CreateAsync(organization);
|
|
savedOrganizations.Add(await sqlOrganizationRepo.GetByIdAsync(sqlOrganization.Id));
|
|
|
|
var distinctItems = savedOrganizations.Distinct(equalityComparer);
|
|
Assert.True(!distinctItems.Skip(1).Any());
|
|
}
|
|
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void ReplaceAsync_Works_DataMatches(Organization postOrganization,
|
|
Organization replaceOrganization, SqlRepo.OrganizationRepository sqlOrganizationRepo,
|
|
OrganizationCompare equalityComparer, List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
var savedOrganizations = new List<Organization>();
|
|
foreach (var sut in suts)
|
|
{
|
|
var postEfOrganization = await sut.CreateAsync(postOrganization);
|
|
sut.ClearChangeTracking();
|
|
|
|
replaceOrganization.Id = postEfOrganization.Id;
|
|
await sut.ReplaceAsync(replaceOrganization);
|
|
sut.ClearChangeTracking();
|
|
|
|
var replacedOrganization = await sut.GetByIdAsync(replaceOrganization.Id);
|
|
savedOrganizations.Add(replacedOrganization);
|
|
}
|
|
|
|
var postSqlOrganization = await sqlOrganizationRepo.CreateAsync(postOrganization);
|
|
replaceOrganization.Id = postSqlOrganization.Id;
|
|
await sqlOrganizationRepo.ReplaceAsync(replaceOrganization);
|
|
savedOrganizations.Add(await sqlOrganizationRepo.GetByIdAsync(replaceOrganization.Id));
|
|
|
|
var distinctItems = savedOrganizations.Distinct(equalityComparer);
|
|
Assert.True(!distinctItems.Skip(1).Any());
|
|
}
|
|
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void DeleteAsync_Works_DataMatches(Organization organization,
|
|
SqlRepo.OrganizationRepository sqlOrganizationRepo, List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
foreach (var sut in suts)
|
|
{
|
|
var postEfOrganization = await sut.CreateAsync(organization);
|
|
sut.ClearChangeTracking();
|
|
|
|
var savedEfOrganization = await sut.GetByIdAsync(postEfOrganization.Id);
|
|
sut.ClearChangeTracking();
|
|
Assert.True(savedEfOrganization != null);
|
|
|
|
await sut.DeleteAsync(savedEfOrganization);
|
|
sut.ClearChangeTracking();
|
|
|
|
savedEfOrganization = await sut.GetByIdAsync(savedEfOrganization.Id);
|
|
Assert.True(savedEfOrganization == null);
|
|
}
|
|
|
|
var postSqlOrganization = await sqlOrganizationRepo.CreateAsync(organization);
|
|
var savedSqlOrganization = await sqlOrganizationRepo.GetByIdAsync(postSqlOrganization.Id);
|
|
Assert.True(savedSqlOrganization != null);
|
|
|
|
await sqlOrganizationRepo.DeleteAsync(postSqlOrganization);
|
|
savedSqlOrganization = await sqlOrganizationRepo.GetByIdAsync(postSqlOrganization.Id);
|
|
Assert.True(savedSqlOrganization == null);
|
|
}
|
|
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void GetByIdentifierAsync_Works_DataMatches(Organization organization,
|
|
SqlRepo.OrganizationRepository sqlOrganizationRepo, OrganizationCompare equalityComparer,
|
|
List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
var returnedOrgs = new List<Organization>();
|
|
foreach (var sut in suts)
|
|
{
|
|
var postEfOrg = await sut.CreateAsync(organization);
|
|
sut.ClearChangeTracking();
|
|
|
|
var returnedOrg = await sut.GetByIdentifierAsync(postEfOrg.Identifier.ToUpperInvariant());
|
|
returnedOrgs.Add(returnedOrg);
|
|
}
|
|
|
|
var postSqlOrg = await sqlOrganizationRepo.CreateAsync(organization);
|
|
returnedOrgs.Add(await sqlOrganizationRepo.GetByIdentifierAsync(postSqlOrg.Identifier.ToUpperInvariant()));
|
|
|
|
var distinctItems = returnedOrgs.Distinct(equalityComparer);
|
|
Assert.True(!distinctItems.Skip(1).Any());
|
|
}
|
|
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void GetManyByEnabledAsync_Works_DataMatches(Organization organization,
|
|
SqlRepo.OrganizationRepository sqlOrganizationRepo, List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
var returnedOrgs = new List<Organization>();
|
|
foreach (var sut in suts)
|
|
{
|
|
var postEfOrg = await sut.CreateAsync(organization);
|
|
sut.ClearChangeTracking();
|
|
|
|
var efReturnedOrgs = await sut.GetManyByEnabledAsync();
|
|
returnedOrgs.Concat(efReturnedOrgs);
|
|
}
|
|
|
|
var postSqlOrg = await sqlOrganizationRepo.CreateAsync(organization);
|
|
returnedOrgs.Concat(await sqlOrganizationRepo.GetManyByEnabledAsync());
|
|
|
|
Assert.True(returnedOrgs.All(o => o.Enabled));
|
|
}
|
|
|
|
// testing data matches here would require manipulating all organization abilities in the db
|
|
[CiSkippedTheory, EfOrganizationAutoData]
|
|
public async void GetManyAbilitiesAsync_Works(SqlRepo.OrganizationRepository sqlOrganizationRepo, List<EfRepo.OrganizationRepository> suts)
|
|
{
|
|
var list = new List<OrganizationAbility>();
|
|
foreach (var sut in suts)
|
|
{
|
|
list.Concat(await sut.GetManyAbilitiesAsync());
|
|
}
|
|
|
|
list.Concat(await sqlOrganizationRepo.GetManyAbilitiesAsync());
|
|
Assert.True(list.All(x => x.GetType() == typeof(OrganizationAbility)));
|
|
}
|
|
}
|
|
}
|