@Test(groups = "fast") public void testNonNullEndDate() throws Exception { final LocalDate startDate = new LocalDate(2012, 12, 1); final LocalDate endDate = new LocalDate(2012, 12, 31); final RecurringInvoiceItem recurringItem = new RecurringInvoiceItem(UUID.randomUUID(), UUID.randomUUID(), null, null, UUID.randomUUID().toString(), UUID.randomUUID().toString(), startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, Currency.USD); checkOutput(recurringItem, "{{#invoiceItem}}<td>{{formattedStartDate}}{{#formattedEndDate}} - {{formattedEndDate}}{{/formattedEndDate}}</td>{{/invoiceItem}}", "<td>Dec 1, 2012 - Dec 31, 2012</td>"); }
@Test(groups = "fast") public void testShouldntFindRepareeForFullRepairs() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem annual = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); // There is no reparee - full repair // New item final LocalDate endDate2 = new LocalDate(2012, 6, 1); final InvoiceItem monthly = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, "new-" + planName, phaseName, startDate, endDate2, BigDecimal.TEN, BigDecimal.TEN, currency); assertFalse(defaultInvoiceGenerator.isRepareeItemForRepairedItem(annual, annual)); assertFalse(defaultInvoiceGenerator.isRepareeItemForRepairedItem(annual, monthly)); }
/********************************************* isRepareeItemForRepairedItem logic ********************************/ @Test(groups = "fast") public void testShouldFindRepareeForPartialRepairs() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate endDate = new LocalDate(2012, 6, 1); // Repaired item final InvoiceItem silver = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); // Reparee item final LocalDate actualEndDateSilver = new LocalDate(2012, 5, 10); final InvoiceItem actualSilver = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, actualEndDateSilver, new BigDecimal("3"), BigDecimal.TEN, currency); // New item final InvoiceItem gold = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, "new-" + planName, phaseName, actualEndDateSilver, endDate, BigDecimal.TEN, new BigDecimal("15"), currency); assertFalse(defaultInvoiceGenerator.isRepareeItemForRepairedItem(silver, silver)); assertFalse(defaultInvoiceGenerator.isRepareeItemForRepairedItem(silver, gold)); assertTrue(defaultInvoiceGenerator.isRepareeItemForRepairedItem(silver, actualSilver)); }
@Test(groups = "fast") public void testRemoveProposedRepareeForPartialRepair2() { final LocalDate startDate = new LocalDate(2012, 6, 30); final LocalDate blockDate = new LocalDate(2012, 7, 10); final LocalDate unblockDate = new LocalDate(2012, 7, 23); final LocalDate endDate = new LocalDate(2012, 7, 31); final BigDecimal someAmount = new BigDecimal("100.00"); final List<InvoiceItem> existing = new LinkedList<InvoiceItem>(); final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, someAmount, someAmount, currency); existing.add(repairedItem); final List<InvoiceItem> proposed = new LinkedList<InvoiceItem>(); final InvoiceItem reparee1 = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, blockDate, someAmount, someAmount, currency); proposed.add(reparee1); final InvoiceItem reparee2 = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, unblockDate, endDate, someAmount, someAmount, currency); proposed.add(reparee2); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, blockDate, unblockDate, someAmount, currency, repairedItem.getId()); defaultInvoiceGenerator.removeProposedRepareesForPartialrepair(repairedItem, repairItem, proposed); assertEquals(proposed.size(), 0); }
@Test(groups = "fast") public void testIsRepareeIncludedInRepairWrongSubscription() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final UUID otherSubscriptionId = UUID.fromString("a9cbee45-5796-4dc5-be1f-7c020518460d"); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, otherSubscriptionId, planName, phaseName, startRepair, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); assertFalse(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
@Test(groups = "fast") public void testIsRepareeIncludedInRepair3() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startRepair, endDate.minusDays(1), BigDecimal.TEN, BigDecimal.TEN, currency); assertTrue(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
@Test(groups = "fast") public void testIsRepareeIncludedInRepair4() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startRepair, endDate.minusDays(1), BigDecimal.TEN, BigDecimal.TEN, currency); assertTrue(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
/********************************************* isRepareeIncludedInRepair logic ********************************/ // Check for an item whose start and endDate exactly fit in repair item @Test(groups = "fast") public void testIsRepareeIncludedInRepair1() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startRepair, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); assertTrue(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
@Test(groups = "fast") public void testIsRepareeIncludedInRepair2() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startRepair.plusDays(1), endDate, BigDecimal.TEN, BigDecimal.TEN, currency); assertTrue(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
@Test(groups = "fast") public void testIsRepareeIncludedInRepair5() throws Exception { final LocalDate startDate = new LocalDate(2012, 5, 1); final LocalDate startRepair = new LocalDate(2012, 8, 1); final LocalDate endDate = new LocalDate(2013, 5, 1); // Repaired item final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, BigDecimal.TEN, BigDecimal.TEN, currency); final InvoiceItem repairItem = new RepairAdjInvoiceItem(invoiceId, accountId, startRepair, endDate, BigDecimal.ONE, currency, repairedItem.getId()); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startRepair, endDate.plusDays(1), BigDecimal.TEN, BigDecimal.TEN, currency); assertFalse(defaultInvoiceGenerator.isRepareeIncludedInRepair(repairItem, repairedItem.getSubscriptionId(), invoiceItem)); }
private InvoiceItem createRecurringInvoiceItemForRepair(final LocalDate startDate, final LocalDate endDate, final InvoiceItem repairedItem, final int nbTotalRepairedDays) { final BigDecimal amount = InvoiceDateUtils.calculateProrationBetweenDates(startDate, endDate, nbTotalRepairedDays).multiply(repairedItem.getRate()).setScale(NUMBER_OF_DECIMALS, ROUNDING_MODE); return new RecurringInvoiceItem(repairedItem.getInvoiceId(), repairedItem.getAccountId(), repairedItem.getBundleId(), repairedItem.getSubscriptionId(), repairedItem.getPlanName(), repairedItem.getPhaseName(), startDate, endDate, amount, repairedItem.getRate(), repairedItem.getCurrency()); }
@Test(groups = "slow") public void testAddInvoiceItemAdjustmentForPartialAmount() throws Exception { final Invoice invoice = new DefaultInvoice(UUID.randomUUID(), clock.getUTCToday(), clock.getUTCToday(), Currency.USD); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoice.getId(), invoice.getAccountId(), UUID.randomUUID(), UUID.randomUUID(), "test plan", "test phase", new LocalDate(2010, 1, 1), new LocalDate(2010, 4, 1), INVOICE_ITEM_AMOUNT, new BigDecimal("7.00"), Currency.USD); invoice.addInvoiceItem(invoiceItem); invoiceUtil.createInvoice(invoice, true, internalCallContext); final InvoiceItemModelDao adjustedInvoiceItem = createAndCheckAdjustment(invoice, invoiceItem, BigDecimal.TEN); Assert.assertEquals(adjustedInvoiceItem.getAmount().compareTo(BigDecimal.TEN.negate()), 0); }
@Test(groups = "fast") public void testRemoveDuplicatedInvoiceItemsShouldNotThrowIllegalStateExceptionOne() { final LocalDate startDate = clock.getUTCToday(); final LocalDate endDate = startDate.plusMonths(1); final BigDecimal amount = new BigDecimal("12.00"); // More items in existing than proposed final List<InvoiceItem> existing = new LinkedList<InvoiceItem>(); final InvoiceItem item1 = new FixedPriceInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, amount, currency); final InvoiceItem item2 = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, amount, amount, currency); existing.add(item1); existing.add(item2); final List<InvoiceItem> proposed = new LinkedList<InvoiceItem>(); final InvoiceItem other1 = new FixedPriceInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, amount, currency); proposed.add(other1); defaultInvoiceGenerator.removeMatchingInvoiceItems(proposed, existing); assertEquals(existing.size(), 1); assertEquals(proposed.size(), 0); }
@Test(groups = "fast") public void testRemoveDuplicatedInvoiceItemsShouldNotThrowIllegalStateExceptionTwo() { final LocalDate startDate = clock.getUTCToday(); final LocalDate endDate = startDate.plusMonths(1); final BigDecimal amount = new BigDecimal("12.00"); // More items in proposed than existing final List<InvoiceItem> existing = new LinkedList<InvoiceItem>(); final InvoiceItem item1 = new FixedPriceInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, amount, currency); existing.add(item1); final List<InvoiceItem> proposed = new LinkedList<InvoiceItem>(); final InvoiceItem other1 = new FixedPriceInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, amount, currency); final InvoiceItem other2 = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, amount, amount, currency); proposed.add(other1); proposed.add(other2); defaultInvoiceGenerator.removeMatchingInvoiceItems(proposed, existing); assertEquals(existing.size(), 0); assertEquals(proposed.size(), 1); }
@Test(groups = "slow") public void testAddInvoiceItemAdjustmentForFullAmount() throws Exception { final Invoice invoice = new DefaultInvoice(UUID.randomUUID(), clock.getUTCToday(), clock.getUTCToday(), Currency.USD); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoice.getId(), invoice.getAccountId(), UUID.randomUUID(), UUID.randomUUID(), "test plan", "test phase", new LocalDate(2010, 1, 1), new LocalDate(2010, 4, 1), INVOICE_ITEM_AMOUNT, new BigDecimal("7.00"), Currency.USD); invoice.addInvoiceItem(invoiceItem); invoiceUtil.createInvoice(invoice, true, internalCallContext); final InvoiceItemModelDao adjustedInvoiceItem = createAndCheckAdjustment(invoice, invoiceItem, null); Assert.assertEquals(adjustedInvoiceItem.getAmount().compareTo(invoiceItem.getAmount().negate()), 0); }
@Test(groups = "slow") public void testGetInvoiceItemsBySubscriptionId() throws EntityPersistenceException { final UUID accountId = account.getId(); final UUID subscriptionId = UUID.randomUUID(); final UUID bundleId = UUID.randomUUID(); final LocalDate startDate = new LocalDate(2011, 3, 1); final BigDecimal rate = new BigDecimal("20.00"); for (int i = 0; i < 3; i++) { final UUID invoiceId = UUID.randomUUID(); final RecurringInvoiceItem item = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, "test plan", "test phase", startDate.plusMonths(i), startDate.plusMonths(i + 1), rate, rate, Currency.USD); invoiceUtil.createInvoiceItem(item, context); } final List<InvoiceItemModelDao> items = invoiceUtil.getInvoiceItemBySubscriptionId(subscriptionId, context); assertEquals(items.size(), 3); }
@Test(groups = "fast") public void testAddRepairedItem2() { final LocalDate startDate = new LocalDate(2013, 12, 1); final LocalDate endDate = new LocalDate(2014, 12, 1); final LocalDate endDateProposed1 = new LocalDate(2014, 1, 1); final BigDecimal rate = new BigDecimal("120.00"); final BigDecimal amount = rate; final InvoiceItem repairedItem = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDate, amount, rate, currency); final RepairAdjInvoiceItem candidateRepairItem = new RepairAdjInvoiceItem(repairedItem.getInvoiceId(), repairedItem.getAccountId(), repairedItem.getStartDate(), repairedItem.getEndDate(), repairedItem.getAmount().negate(), repairedItem.getCurrency(), repairedItem.getId()); final List<InvoiceItem> proposed = new LinkedList<InvoiceItem>(); final InvoiceItem proposed1 = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, endDateProposed1, BigDecimal.TEN, rate, currency); proposed.add(proposed1); defaultInvoiceGenerator.addRepairsForItem(repairedItem, candidateRepairItem, proposed); assertEquals(proposed.size(), 1); assertEquals(proposed.get(0).getStartDate(), endDateProposed1); assertEquals(proposed.get(0).getEndDate(), endDate); assertEquals(proposed.get(0).getLinkedItemId(), repairedItem.getId()); assertEquals(proposed.get(0).getAmount(), new BigDecimal("-110.00")); assertEquals(proposed.get(0).getInvoiceItemType(), InvoiceItemType.REPAIR_ADJ); }
@Test(groups = "fast") public void testRemoveCancellingInvoiceItemsFixedPrice() { final LocalDate startDate = clock.getUTCToday(); final LocalDate endDate = startDate.plusDays(30); final LocalDate nextEndDate = startDate.plusMonths(1); final BigDecimal amount = new BigDecimal("12.00"); final BigDecimal rate2 = new BigDecimal("14.85"); final BigDecimal amount2 = rate2; final List<InvoiceItem> items = new LinkedList<InvoiceItem>(); final InvoiceItem item1 = new FixedPriceInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, startDate, amount, currency); items.add(item1); items.add(new RepairAdjInvoiceItem(invoiceId, accountId, startDate, endDate, amount.negate(), currency, item1.getId())); items.add(new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, planName, phaseName, endDate, nextEndDate, amount2, rate2, currency)); defaultInvoiceGenerator.removeRepairedAndRepairInvoiceItems(items, new LinkedList<InvoiceItem>()); assertEquals(items.size(), 1); final InvoiceItem leftItem = items.get(0); assertEquals(leftItem.getInvoiceItemType(), InvoiceItemType.RECURRING); assertEquals(leftItem.getAmount(), amount2); }
@Test(groups = "slow") public void testGetInvoiceItemsByAccountId() throws EntityPersistenceException { final UUID accountId = account.getId(); final UUID bundleId = UUID.randomUUID(); final LocalDate targetDate = new LocalDate(2011, 5, 23); final DefaultInvoice invoice = new DefaultInvoice(accountId, clock.getUTCToday(), targetDate, Currency.USD); invoiceUtil.createInvoice(invoice, true, context); final UUID invoiceId = invoice.getId(); final LocalDate startDate = new LocalDate(2011, 3, 1); final BigDecimal rate = new BigDecimal("20.00"); final UUID subscriptionId = UUID.randomUUID(); final RecurringInvoiceItem item = new RecurringInvoiceItem(invoiceId, accountId, bundleId, subscriptionId, "test plan", "test phase", startDate, startDate.plusMonths(1), rate, rate, Currency.USD); invoiceUtil.createInvoiceItem(item, context); final List<InvoiceItemModelDao> items = invoiceUtil.getInvoiceItemByAccountId(context); assertEquals(items.size(), 1); }
@Test(groups = "slow") public void testAddInvoiceItemAdjustmentForWrongInvoice() throws Exception { final Invoice invoice = new DefaultInvoice(UUID.randomUUID(), clock.getUTCToday(), clock.getUTCToday(), Currency.USD); final InvoiceItem invoiceItem = new RecurringInvoiceItem(invoice.getId(), invoice.getAccountId(), UUID.randomUUID(), UUID.randomUUID(), "test plan", "test phase", new LocalDate(2010, 1, 1), new LocalDate(2010, 4, 1), INVOICE_ITEM_AMOUNT, new BigDecimal("7.00"), Currency.USD); invoice.addInvoiceItem(invoiceItem); invoiceUtil.createInvoice(invoice, true, internalCallContext); try { invoiceDao.insertInvoiceItemAdjustment(invoice.getAccountId(), UUID.randomUUID(), invoiceItem.getId(), new LocalDate(2010, 1, 1), null, null, internalCallContext); Assert.fail("Should not have been able to adjust an item on a non existing invoice"); } catch (Exception e) { Assert.assertEquals(((InvoiceApiException) e.getCause()).getCode(), ErrorCode.INVOICE_INVALID_FOR_INVOICE_ITEM_ADJUSTMENT.getCode()); } }