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.
64 lines
2.4 KiB
64 lines
2.4 KiB
using Bit.Core.AdminConsole.Entities; |
|
using Bit.Core.Entities; |
|
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 SqlRepo = Bit.Infrastructure.Dapper.Repositories; |
|
|
|
namespace Bit.Infrastructure.EFIntegration.Test.Repositories; |
|
|
|
public class TransactionRepositoryTests |
|
{ |
|
|
|
[CiSkippedTheory, EfUserTransactionAutoData, EfOrganizationTransactionAutoData] |
|
public async void CreateAsync_Works_DataMatches( |
|
Transaction transaction, |
|
User user, |
|
Organization org, |
|
TransactionCompare equalityComparer, |
|
List<EfRepo.TransactionRepository> suts, |
|
List<EfRepo.UserRepository> efUserRepos, |
|
List<EfRepo.OrganizationRepository> efOrgRepos, |
|
SqlRepo.TransactionRepository sqlTransactionRepo, |
|
SqlRepo.UserRepository sqlUserRepo, |
|
SqlRepo.OrganizationRepository sqlOrgRepo |
|
) |
|
{ |
|
var savedTransactions = new List<Transaction>(); |
|
foreach (var sut in suts) |
|
{ |
|
var i = suts.IndexOf(sut); |
|
var efUser = await efUserRepos[i].CreateAsync(user); |
|
if (transaction.OrganizationId.HasValue) |
|
{ |
|
var efOrg = await efOrgRepos[i].CreateAsync(org); |
|
transaction.OrganizationId = efOrg.Id; |
|
} |
|
sut.ClearChangeTracking(); |
|
|
|
transaction.UserId = efUser.Id; |
|
var postEfTransaction = await sut.CreateAsync(transaction); |
|
sut.ClearChangeTracking(); |
|
|
|
var savedTransaction = await sut.GetByIdAsync(postEfTransaction.Id); |
|
savedTransactions.Add(savedTransaction); |
|
} |
|
|
|
var sqlUser = await sqlUserRepo.CreateAsync(user); |
|
if (transaction.OrganizationId.HasValue) |
|
{ |
|
var sqlOrg = await sqlOrgRepo.CreateAsync(org); |
|
transaction.OrganizationId = sqlOrg.Id; |
|
} |
|
|
|
transaction.UserId = sqlUser.Id; |
|
var sqlTransaction = await sqlTransactionRepo.CreateAsync(transaction); |
|
var savedSqlTransaction = await sqlTransactionRepo.GetByIdAsync(sqlTransaction.Id); |
|
savedTransactions.Add(savedSqlTransaction); |
|
|
|
var distinctItems = savedTransactions.Distinct(equalityComparer); |
|
Assert.True(!distinctItems.Skip(1).Any()); |
|
} |
|
}
|
|
|