/**
* Copyright (C) 2015 - present by OpenGamma Inc. and the OpenGamma group of companies
*
* Please see distribution for license.
*/
package com.opengamma.strata.market.curve.node;
import static com.opengamma.strata.basics.currency.Currency.EUR;
import static com.opengamma.strata.basics.date.BusinessDayConventions.MODIFIED_FOLLOWING;
import static com.opengamma.strata.basics.date.DayCounts.ACT_360;
import static com.opengamma.strata.basics.date.HolidayCalendarIds.EUTA;
import static com.opengamma.strata.collect.TestHelper.assertSerialization;
import static com.opengamma.strata.collect.TestHelper.assertThrows;
import static com.opengamma.strata.collect.TestHelper.assertThrowsWithCause;
import static com.opengamma.strata.collect.TestHelper.coverBeanEquals;
import static com.opengamma.strata.collect.TestHelper.coverImmutableBean;
import static com.opengamma.strata.collect.TestHelper.date;
import static org.testng.Assert.assertEquals;
import static org.testng.Assert.assertFalse;
import java.time.LocalDate;
import java.time.Period;
import java.util.Iterator;
import java.util.Set;
import org.testng.annotations.Test;
import com.opengamma.strata.basics.ReferenceData;
import com.opengamma.strata.basics.StandardId;
import com.opengamma.strata.basics.date.BusinessDayAdjustment;
import com.opengamma.strata.basics.date.DaysAdjustment;
import com.opengamma.strata.basics.date.Tenor;
import com.opengamma.strata.data.ImmutableMarketData;
import com.opengamma.strata.data.MarketData;
import com.opengamma.strata.data.MarketDataNotFoundException;
import com.opengamma.strata.data.ObservableId;
import com.opengamma.strata.market.ValueType;
import com.opengamma.strata.market.curve.CurveNodeDate;
import com.opengamma.strata.market.observable.QuoteId;
import com.opengamma.strata.market.param.DatedParameterMetadata;
import com.opengamma.strata.market.param.ParameterMetadata;
import com.opengamma.strata.market.param.TenorDateParameterMetadata;
import com.opengamma.strata.product.TradeInfo;
import com.opengamma.strata.product.common.BuySell;
import com.opengamma.strata.product.deposit.TermDeposit;
import com.opengamma.strata.product.deposit.TermDepositTrade;
import com.opengamma.strata.product.deposit.type.TermDepositConvention;
import com.opengamma.strata.product.deposit.type.TermDepositConventions;
import com.opengamma.strata.product.deposit.type.TermDepositTemplate;
/**
* Test {@link TermDepositCurveNode}.
*/
@Test
public class TermDepositCurveNodeTest {
private static final ReferenceData REF_DATA = ReferenceData.standard();
private static final LocalDate VAL_DATE = date(2015, 6, 30);
private static final BusinessDayAdjustment BDA_MOD_FOLLOW = BusinessDayAdjustment.of(MODIFIED_FOLLOWING, EUTA);
private static final DaysAdjustment PLUS_TWO_DAYS = DaysAdjustment.ofBusinessDays(2, EUTA);
private static final TermDepositConvention CONVENTION = TermDepositConventions.EUR_DEPOSIT_T2;
private static final Period DEPOSIT_PERIOD = Period.ofMonths(3);
private static final TermDepositTemplate TEMPLATE = TermDepositTemplate.of(DEPOSIT_PERIOD, CONVENTION);
private static final QuoteId QUOTE_ID = QuoteId.of(StandardId.of("OG-Ticker", "Deposit1"));
private static final double SPREAD = 0.0015;
private static final String LABEL = "Label";
private static final String LABEL_AUTO = "3M";
public void test_builder() {
TermDepositCurveNode test = TermDepositCurveNode.builder()
.label(LABEL)
.template(TEMPLATE)
.rateId(QUOTE_ID)
.additionalSpread(SPREAD)
.date(CurveNodeDate.LAST_FIXING)
.build();
assertEquals(test.getLabel(), LABEL);
assertEquals(test.getRateId(), QUOTE_ID);
assertEquals(test.getAdditionalSpread(), SPREAD);
assertEquals(test.getTemplate(), TEMPLATE);
assertEquals(test.getDate(), CurveNodeDate.LAST_FIXING);
}
public void test_builder_defaults() {
TermDepositCurveNode test = TermDepositCurveNode.builder()
.label(LABEL)
.template(TEMPLATE)
.rateId(QUOTE_ID)
.additionalSpread(SPREAD)
.build();
assertEquals(test.getLabel(), LABEL);
assertEquals(test.getRateId(), QUOTE_ID);
assertEquals(test.getAdditionalSpread(), SPREAD);
assertEquals(test.getTemplate(), TEMPLATE);
assertEquals(test.getDate(), CurveNodeDate.END);
}
public void test_of_noSpread() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID);
assertEquals(test.getLabel(), LABEL_AUTO);
assertEquals(test.getRateId(), QUOTE_ID);
assertEquals(test.getAdditionalSpread(), 0.0d);
assertEquals(test.getTemplate(), TEMPLATE);
}
public void test_of_withSpread() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
assertEquals(test.getLabel(), LABEL_AUTO);
assertEquals(test.getRateId(), QUOTE_ID);
assertEquals(test.getAdditionalSpread(), SPREAD);
assertEquals(test.getTemplate(), TEMPLATE);
}
public void test_of_withSpreadAndLabel() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD, LABEL);
assertEquals(test.getLabel(), LABEL);
assertEquals(test.getRateId(), QUOTE_ID);
assertEquals(test.getAdditionalSpread(), SPREAD);
assertEquals(test.getTemplate(), TEMPLATE);
}
public void test_requirements() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
Set<ObservableId> set = test.requirements();
Iterator<ObservableId> itr = set.iterator();
assertEquals(itr.next(), QUOTE_ID);
assertFalse(itr.hasNext());
}
public void test_trade() {
TermDepositCurveNode node = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
double rate = 0.035;
MarketData marketData = ImmutableMarketData.builder(VAL_DATE).addValue(QUOTE_ID, rate).build();
TermDepositTrade trade = node.trade(1d, marketData, REF_DATA);
LocalDate startDateExpected = PLUS_TWO_DAYS.adjust(VAL_DATE, REF_DATA);
LocalDate endDateExpected = startDateExpected.plus(DEPOSIT_PERIOD);
TermDeposit depositExpected = TermDeposit.builder()
.buySell(BuySell.BUY)
.currency(EUR)
.dayCount(ACT_360)
.startDate(startDateExpected)
.endDate(endDateExpected)
.notional(1.0d)
.businessDayAdjustment(BDA_MOD_FOLLOW)
.rate(rate + SPREAD)
.build();
TradeInfo tradeInfoExpected = TradeInfo.builder()
.tradeDate(VAL_DATE)
.build();
assertEquals(trade.getProduct(), depositExpected);
assertEquals(trade.getInfo(), tradeInfoExpected);
}
public void test_trade_noMarketData() {
TermDepositCurveNode node = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
LocalDate valuationDate = LocalDate.of(2015, 1, 22);
MarketData marketData = MarketData.empty(valuationDate);
assertThrows(() -> node.trade(1d, marketData, REF_DATA), MarketDataNotFoundException.class);
}
public void test_initialGuess() {
TermDepositCurveNode node = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
double rate = 0.035;
MarketData marketData = ImmutableMarketData.builder(VAL_DATE).addValue(QUOTE_ID, rate).build();
assertEquals(node.initialGuess(marketData, ValueType.ZERO_RATE), rate);
assertEquals(node.initialGuess(marketData, ValueType.FORWARD_RATE), rate);
assertEquals(node.initialGuess(marketData, ValueType.DISCOUNT_FACTOR),
Math.exp(-rate * 0.25), 1.0e-12);
}
public void test_metadata_end() {
TermDepositCurveNode node = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
LocalDate valuationDate = LocalDate.of(2015, 1, 22);
ParameterMetadata metadata = node.metadata(valuationDate, REF_DATA);
assertEquals(((TenorDateParameterMetadata) metadata).getDate(), LocalDate.of(2015, 4, 27));
assertEquals(((TenorDateParameterMetadata) metadata).getTenor(), Tenor.TENOR_3M);
}
public void test_metadata_fixed() {
LocalDate nodeDate = VAL_DATE.plusMonths(1);
TermDepositCurveNode node =
TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD).withDate(CurveNodeDate.of(nodeDate));
LocalDate valuationDate = LocalDate.of(2015, 1, 22);
DatedParameterMetadata metadata = node.metadata(valuationDate, REF_DATA);
assertEquals(metadata.getDate(), nodeDate);
assertEquals(metadata.getLabel(), node.getLabel());
}
public void test_metadata_last_fixing() {
TermDepositCurveNode node =
TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD).withDate(CurveNodeDate.LAST_FIXING);
assertThrowsWithCause(() -> node.metadata(VAL_DATE, REF_DATA), UnsupportedOperationException.class);
}
//-------------------------------------------------------------------------
public void coverage() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
coverImmutableBean(test);
TermDepositCurveNode test2 = TermDepositCurveNode.of(
TermDepositTemplate.of(Period.ofMonths(1), CONVENTION), QuoteId.of(StandardId.of("OG-Ticker", "Deposit2")));
coverBeanEquals(test, test2);
}
public void test_serialization() {
TermDepositCurveNode test = TermDepositCurveNode.of(TEMPLATE, QUOTE_ID, SPREAD);
assertSerialization(test);
}
}