public async Task AutoResolveMappingErrors_4Entries_AutoResolve3() { var options = TestHelper.GetDbContext("AutoResolveMappingErrors_4Entries_AutoResolve3"); var user1 = TestHelper.InsertUserDetailed(options); var client1 = TestHelper.InsertClient(options, user1.Organisation); var statement = TestHelper.InsertCommissionStatement(options, user1.Organisation); var commissionTypeId = Guid.NewGuid(); var company1 = TestHelper.InsertCompany(options); var policyAliasNumber1 = "98765"; var policy1 = new PolicyEntity { Id = Guid.NewGuid(), Number = "123456", CompanyId = company1.Id, ClientId = client1.Client.Id, UserId = user1.User.Id, NumberAliases = new List <string>() { policyAliasNumber1 } }; // ENTRY 1: POLICY 1 ----------------------- var ic1a = new ImportCommission { PolicyNumber = policy1.Number, CommissionTypeCode = "gap_cover", AmountIncludingVAT = "11", VAT = "22" }; var err1a = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, CommissionTypeId = commissionTypeId, Data = ic1a }; //------------------------------------------ // ENTRY 2: POLICY 1 ----------------------- var ic1b = new ImportCommission { PolicyNumber = policy1.Number, CommissionTypeCode = "gap_cover", AmountIncludingVAT = "33", VAT = "44" }; var err1b = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, CommissionTypeId = commissionTypeId, Data = ic1b }; //------------------------------------------ // ENTRY 3: POLICY ? ----------------------- var ic2 = new ImportCommission { PolicyNumber = "654321", CommissionTypeCode = "gap_cover", AmountIncludingVAT = "55", VAT = "66" }; var err2 = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, CommissionTypeId = commissionTypeId, Data = ic2 }; //------------------------------------------ // ENTRY 4: POLICY 1 ----------------------- var ic1c = new ImportCommission { PolicyNumber = policyAliasNumber1, CommissionTypeCode = "gap_cover", AmountIncludingVAT = "77", VAT = "88" }; var err1c = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, CommissionTypeId = commissionTypeId, Data = ic1c }; //------------------------------------------ using (var context = new DataContext(options)) { context.CommissionError.Add(err1a); context.CommissionError.Add(err2); context.CommissionError.Add(err1b); context.CommissionError.Add(err1c); context.Policy.Add(policy1); context.SaveChanges(); var error1 = new CommissionError { Id = err1a.Id, CommissionStatementId = statement.Id, PolicyId = policy1.Id, ClientId = policy1.ClientId, CommissionTypeId = err1a.CommissionTypeId, Data = ic1a }; var auditService = new AuditServiceMock(); var commissionService = new CommissionService(context, auditService); var clientService = new ClientService(context, auditService); var policyService = new PolicyService(context, auditService); var commissionSplitService = new CommissionSplitService(context, auditService); var commissionSplitRulePolicyService = new CommissionSplitRulePolicyService(context, commissionSplitService, auditService); var service = new CommissionErrorService(context, commissionService, clientService, commissionSplitService, policyService, commissionSplitRulePolicyService, auditService); //When var scope = TestHelper.GetScopeOptions(user1); await service.AutoResolveMappingErrors(scope, statement.Id, policy1.Id); //Then var actualErrors = context.CommissionError.ToList(); Assert.Single(actualErrors); Assert.Equal(err2.Id, actualErrors[0].Id); var commissions = context.Commission.ToList(); Assert.Equal(3, commissions.Count); var actual = commissions[0]; Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.CommissionStatementId, actual.CommissionStatementId); Assert.Equal(error1.CommissionTypeId, actual.CommissionTypeId); Assert.Equal(11, actual.AmountIncludingVAT); Assert.Equal(22, actual.VAT); Assert.Equal(err1a.Data, actual.SourceData); actual = commissions[1]; Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.CommissionStatementId, actual.CommissionStatementId); Assert.Equal(error1.CommissionTypeId, actual.CommissionTypeId); Assert.Equal(33, actual.AmountIncludingVAT); Assert.Equal(44, actual.VAT); Assert.Equal(err1b.Data, actual.SourceData); actual = commissions[2]; Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.CommissionStatementId, actual.CommissionStatementId); Assert.Equal(error1.CommissionTypeId, actual.CommissionTypeId); Assert.Equal(77, actual.AmountIncludingVAT); Assert.Equal(88, actual.VAT); Assert.Equal(err1c.Data, actual.SourceData); } }
public async Task ResolveMappingError_Pass_UpdateMemberDetails() { var options = TestHelper.GetDbContext("ResolveMappingError_Pass_UpdateMemberDetails"); var user1 = TestHelper.InsertUserDetailed(options); var statement = TestHelper.InsertCommissionStatement(options, user1.Organisation); var company1 = TestHelper.InsertCompany(options); var client1 = new ClientEntity { Id = Guid.NewGuid(), ClientTypeId = ClientType.CLIENT_TYPE_INDIVIDUAL, FirstName = "", LastName = "", IdNumber = "", OrganisationId = user1.Organisation.Id, Initials = "", DateOfBirth = null, TaxNumber = Guid.NewGuid().ToString() }; var policy1 = new PolicyEntity { Id = Guid.NewGuid(), CompanyId = company1.Id, ClientId = client1.Id, UserId = user1.User.Id }; var ic1 = new ImportCommission { PolicyNumber = "123456", CommissionTypeCode = "gap_cover", AmountIncludingVAT = "22", VAT = "33", FirstName = "Dean", LastName = "van Niekerk", IdNumber = "8210035032082", DateOfBirth = "1982-10-03", Initials = "DJ" }; var err1 = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, Data = ic1 }; using (var context = new DataContext(options)) { context.Client.Add(client1); context.CommissionError.Add(err1); context.Policy.Add(policy1); context.SaveChanges(); var error1 = new CommissionErrorEdit { Id = err1.Id, CommissionStatementId = statement.Id, PolicyId = policy1.Id, ClientId = policy1.ClientId, CommissionTypeId = Guid.NewGuid(), Data = ic1 }; var auditService = new AuditServiceMock(); var commissionService = new CommissionService(context, auditService); var clientService = new ClientService(context, auditService); var policyService = new PolicyService(context, auditService); var commissionSplitService = new CommissionSplitService(context, auditService); var commissionSplitRulePolicyService = new CommissionSplitRulePolicyService(context, commissionSplitService, auditService); var service = new CommissionErrorService(context, commissionService, clientService, commissionSplitService, policyService, commissionSplitRulePolicyService, auditService); //When var scope = TestHelper.GetScopeOptions(user1); var result = await service.ResolveMappingError(scope, error1); //Then Assert.True(result.Success); var actual = context.Commission.Single(); Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.CommissionStatementId, actual.CommissionStatementId); Assert.Equal(error1.CommissionTypeId, actual.CommissionTypeId); Assert.Equal(22, actual.AmountIncludingVAT); Assert.Equal(33, actual.VAT); Assert.Equal(error1.Data, actual.SourceData); var actualClient = context.Client.Single(); Assert.Equal(ic1.Initials, actualClient.Initials); Assert.Equal(ic1.FirstName, actualClient.FirstName); Assert.Equal(ic1.LastName, actualClient.LastName); Assert.Equal(ic1.IdNumber, actualClient.IdNumber); Assert.Equal(DateTime.Parse(ic1.DateOfBirth), actualClient.DateOfBirth); } }
public async Task ResolveMappingError_Pass_UpdatePolicyAlias() { var options = TestHelper.GetDbContext("ResolveMappingError_Pass_UpdatePolicyAlias"); var user1 = TestHelper.InsertUserDetailed(options); var client1 = TestHelper.InsertClient(options, user1.Organisation); var statement = TestHelper.InsertCommissionStatement(options, user1.Organisation); var company1 = TestHelper.InsertCompany(options); var policy1 = new PolicyEntity { Id = Guid.NewGuid(), Number = Guid.NewGuid().ToString(), CompanyId = company1.Id, ClientId = client1.Client.Id, UserId = user1.User.Id, NumberAliases = new List <string>() { "987654" } //Existing alias }; var ic1 = new ImportCommission { PolicyNumber = "123456", // Policy number is different CommissionTypeCode = "gap_cover", AmountIncludingVAT = "22", VAT = "33", }; var err1 = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, Data = ic1 }; using (var context = new DataContext(options)) { context.CommissionError.Add(err1); context.Policy.Add(policy1); context.SaveChanges(); var error1 = new CommissionErrorEdit { Id = err1.Id, CommissionStatementId = statement.Id, PolicyId = policy1.Id, ClientId = policy1.ClientId, CommissionTypeId = Guid.NewGuid(), Data = ic1 }; var auditService = new AuditServiceMock(); var commissionService = new CommissionService(context, auditService); var clientService = new ClientService(context, auditService); var policyService = new PolicyService(context, auditService); var commissionSplitService = new CommissionSplitService(context, auditService); var commissionSplitRulePolicyService = new CommissionSplitRulePolicyService(context, commissionSplitService, auditService); var service = new CommissionErrorService(context, commissionService, clientService, commissionSplitService, policyService, commissionSplitRulePolicyService, auditService); //When var scope = TestHelper.GetScopeOptions(user1); var result = await service.ResolveMappingError(scope, error1); //Then Assert.True(result.Success); var actual = context.Commission.Single(); Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.Data, actual.SourceData); var actualPolicy = context.Policy.Single(); Assert.Equal(2, actualPolicy.NumberAliases.Count()); Assert.NotNull(actualPolicy.NumberAliases.SingleOrDefault(n => n == "123456")); //New alias Assert.NotNull(actualPolicy.NumberAliases.SingleOrDefault(n => n == "987654")); //Existing alias } }
public async Task ResolveMappingError_Pass() { var options = TestHelper.GetDbContext("ResolveMappingError_Pass"); var user1 = TestHelper.InsertUserDetailed(options); var client1 = TestHelper.InsertClient(options, user1.Organisation); var statement = TestHelper.InsertCommissionStatement(options, user1.Organisation); var company1 = TestHelper.InsertCompany(options); var policy1 = new PolicyEntity { Id = Guid.NewGuid(), CompanyId = company1.Id, ClientId = client1.Client.Id, UserId = user1.User.Id }; var ic1 = new ImportCommission { PolicyNumber = "123456", CommissionTypeCode = "gap_cover", AmountIncludingVAT = "22", VAT = "33", //These should get ignored as values already exist in db FirstName = "Dean", LastName = "van Niekerk", IdNumber = "8210035032082", DateOfBirth = "1982-10-03", Initials = "DJ" }; var err1 = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, Data = ic1 }; var err2 = new CommissionErrorEntity { Id = Guid.NewGuid(), CommissionStatementId = statement.Id, Data = new ImportCommission() }; using (var context = new DataContext(options)) { context.CommissionError.Add(err1); context.CommissionError.Add(err2); context.Policy.Add(policy1); context.SaveChanges(); var error1 = new CommissionErrorEdit { Id = err1.Id, CommissionStatementId = statement.Id, PolicyId = policy1.Id, ClientId = policy1.ClientId, CommissionTypeId = Guid.NewGuid(), Data = ic1 }; var auditService = new AuditServiceMock(); var commissionService = new CommissionService(context, auditService); var clientService = new ClientService(context, auditService); var policyService = new PolicyService(context, auditService); var commissionSplitService = new CommissionSplitService(context, auditService); var commissionSplitRulePolicyService = new CommissionSplitRulePolicyService(context, commissionSplitService, auditService); var service = new CommissionErrorService(context, commissionService, clientService, commissionSplitService, policyService, commissionSplitRulePolicyService, auditService); //When var scope = TestHelper.GetScopeOptions(user1); var result = await service.ResolveMappingError(scope, error1); //Then Assert.True(result.Success); var actualError = context.CommissionError.Single(); Assert.Equal(err2.Id, actualError.Id); var actual = context.Commission.Single(); Assert.Equal(error1.PolicyId, actual.PolicyId); Assert.Equal(error1.CommissionStatementId, actual.CommissionStatementId); Assert.Equal(error1.CommissionTypeId, actual.CommissionTypeId); Assert.Equal(22, actual.AmountIncludingVAT); Assert.Equal(33, actual.VAT); Assert.Equal(error1.Data, actual.SourceData); //These details should not have changed var actualClient = context.Client.Single(); Assert.Equal(client1.Client.Initials, actualClient.Initials); Assert.Equal(client1.Client.FirstName, actualClient.FirstName); Assert.Equal(client1.Client.LastName, actualClient.LastName); Assert.Equal(client1.Client.IdNumber, actualClient.IdNumber); Assert.Equal(client1.Client.DateOfBirth, actualClient.DateOfBirth); } }