/** * Copyright (C) 2013 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.analytics.financial.interestrate.payments.derivative; import static org.testng.AssertJUnit.assertEquals; import static org.testng.AssertJUnit.assertFalse; import org.testng.annotations.Test; import org.threeten.bp.Period; import org.threeten.bp.ZonedDateTime; import com.opengamma.analytics.financial.instrument.index.IborIndex; import com.opengamma.analytics.financial.instrument.index.IndexIborMaster; import com.opengamma.analytics.financial.schedule.ScheduleCalculator; import com.opengamma.analytics.util.time.TimeCalculator; import com.opengamma.financial.convention.calendar.Calendar; import com.opengamma.financial.convention.calendar.MondayToFridayCalendar; import com.opengamma.util.test.TestGroup; import com.opengamma.util.time.DateUtils; /** * Test of fixed compounding coupon class. */ @Test(groups = TestGroup.UNIT) public class CouponFixedCompoundingTest { private static final Calendar NYC = new MondayToFridayCalendar("NYC"); private static final IndexIborMaster MASTER_IBOR = IndexIborMaster.getInstance(); private static final IborIndex USDLIBOR1M = MASTER_IBOR.getIndex("USDLIBOR1M"); private static final Period TENOR_3M = Period.ofMonths(3); private static final ZonedDateTime START_DATE = DateUtils.getUTCDate(2012, 8, 24); private static final double NOTIONAL = 123454321; private static final ZonedDateTime[] ACCRUAL_END_DATES = ScheduleCalculator.getAdjustedDateSchedule(START_DATE, TENOR_3M, true, false, USDLIBOR1M, NYC); private static final int NB_SUB_PERIOD = ACCRUAL_END_DATES.length; private static final ZonedDateTime[] ACCRUAL_START_DATES = new ZonedDateTime[NB_SUB_PERIOD]; private static final double[] PAYMENT_ACCRUAL_FACTORS = new double[NB_SUB_PERIOD]; private static final double PAYMENT_ACCRUAL_FACTOR; static { ACCRUAL_START_DATES[0] = START_DATE; for (int loopsub = 1; loopsub < NB_SUB_PERIOD; loopsub++) { ACCRUAL_START_DATES[loopsub] = ACCRUAL_END_DATES[loopsub - 1]; } double af = 0.0; for (int loopsub = 0; loopsub < NB_SUB_PERIOD; loopsub++) { PAYMENT_ACCRUAL_FACTORS[loopsub] = USDLIBOR1M.getDayCount().getDayCountFraction(ACCRUAL_START_DATES[loopsub], ACCRUAL_END_DATES[loopsub]); af += PAYMENT_ACCRUAL_FACTORS[loopsub]; } PAYMENT_ACCRUAL_FACTOR = af; } private static final ZonedDateTime REFERENCE_DATE = DateUtils.getUTCDate(2012, 8, 17); private static final double[] ACCRUAL_END_TIMES = TimeCalculator.getTimeBetween(REFERENCE_DATE, ACCRUAL_END_DATES); private static final double PAYMENT_TIME = ACCRUAL_END_TIMES[NB_SUB_PERIOD - 1]; private static final double FIXED_RATE = .02; private static final CouponFixedCompounding CPN = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); @Test(expectedExceptions = IllegalArgumentException.class) public void nullCurrency() { new CouponFixedCompounding(null, PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); } @Test(expectedExceptions = IllegalArgumentException.class) public void testNegativePaymentTime() { new CouponFixedCompounding(USDLIBOR1M.getCurrency(), -1, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); } @Test(expectedExceptions = IllegalArgumentException.class) public void testNegativePaymentAccrualFactor() { new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, -1, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); } @Test /** * Tests the getters. */ public void getter() { assertEquals("CouponFixedCompounding: getter", USDLIBOR1M.getCurrency(), CPN.getCurrency()); assertEquals("CouponFixedCompounding: getter", PAYMENT_ACCRUAL_FACTOR, CPN.getPaymentYearFraction()); assertEquals("CouponFixedCompounding: getter", NOTIONAL, CPN.getNotional()); assertEquals("CouponFixedCompounding: getter", PAYMENT_ACCRUAL_FACTORS, CPN.getPaymentAccrualFactors()); assertEquals("CouponFixedCompounding: getter", PAYMENT_TIME, CPN.getPaymentTime()); assertEquals("CouponFixedCompounding: getter", PAYMENT_ACCRUAL_FACTOR, CPN.getPaymentYearFraction()); assertEquals("CouponFixedCompounding: getter", FIXED_RATE, CPN.getFixedRate()); } @Test public void testWithNotional() { final double notional = NOTIONAL + 10000; final CouponFixedCompounding expected = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, notional, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); assertEquals(expected, CPN.withNotional(notional)); } @Test /** * Tests the equal and hash code. */ public void testEqualHash() { assertEquals("CouponIbor: equal-hash", CPN, CPN); final CouponFixedCompounding other = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); assertEquals("CouponIbor: equal-hash", other, CPN); assertEquals("CouponIbor: equal-hash", other.hashCode(), CPN.hashCode()); CouponFixedCompounding modified; modified = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME + .1, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); assertFalse("CouponIbor: equal-hash", CPN.equals(modified)); modified = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR + .1, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); assertFalse("CouponIbor: equal-hash", CPN.equals(modified)); modified = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL + .1, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE); assertFalse("CouponIbor: equal-hash", CPN.equals(modified)); modified = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, new double[1], FIXED_RATE); assertFalse("CouponIbor: equal-hash", CPN.equals(modified)); modified = new CouponFixedCompounding(USDLIBOR1M.getCurrency(), PAYMENT_TIME, PAYMENT_ACCRUAL_FACTOR, NOTIONAL, PAYMENT_ACCRUAL_FACTORS, FIXED_RATE + .1); assertFalse("CouponIbor: equal-hash", CPN.equals(modified)); } }