/** * Copyright (C) 2016 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.strata.measure.fxopt; import static com.opengamma.strata.basics.currency.Currency.EUR; import static com.opengamma.strata.basics.currency.Currency.GBP; import static com.opengamma.strata.basics.currency.Currency.USD; import static com.opengamma.strata.collect.TestHelper.assertSerialization; import static com.opengamma.strata.collect.TestHelper.assertThrowsIllegalArg; 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.mockito.Mockito.mock; import static org.mockito.Mockito.when; import static org.testng.Assert.assertEquals; import java.time.LocalDate; import org.joda.beans.ImmutableBean; import org.testng.annotations.Test; import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableSet; import com.opengamma.strata.basics.currency.CurrencyPair; import com.opengamma.strata.calc.runner.FunctionRequirements; import com.opengamma.strata.data.MarketData; import com.opengamma.strata.data.scenario.ScenarioMarketData; import com.opengamma.strata.measure.curve.TestMarketDataMap; import com.opengamma.strata.pricer.fxopt.FxOptionVolatilities; import com.opengamma.strata.pricer.fxopt.FxOptionVolatilitiesId; /** * Test {@link FxOptionMarketDataLookup}. */ @Test public class FxOptionMarketDataLookupTest { private static final FxOptionVolatilitiesId VOL_ID1 = FxOptionVolatilitiesId.of("EURUSD1"); private static final FxOptionVolatilities MOCK_VOLS = mock(FxOptionVolatilities.class); private static final MarketData MOCK_MARKET_DATA = mock(MarketData.class); private static final ScenarioMarketData MOCK_CALC_MARKET_DATA = mock(ScenarioMarketData.class); private static final CurrencyPair EUR_USD = CurrencyPair.of(EUR, USD); private static final CurrencyPair GBP_USD = CurrencyPair.of(GBP, USD); private static final CurrencyPair EUR_GBP = CurrencyPair.of(EUR, GBP); static { when(MOCK_MARKET_DATA.getValue(VOL_ID1)).thenReturn(MOCK_VOLS); } //------------------------------------------------------------------------- public void test_of_single() { FxOptionMarketDataLookup test = FxOptionMarketDataLookup.of(EUR_USD, VOL_ID1); assertEquals(test.queryType(), FxOptionMarketDataLookup.class); assertEquals(test.getVolatilityCurrencyPairs(), ImmutableSet.of(EUR_USD)); assertEquals(test.getVolatilityIds(EUR_USD), ImmutableSet.of(VOL_ID1)); assertThrowsIllegalArg(() -> test.getVolatilityIds(GBP_USD)); assertEquals( test.requirements(EUR_USD), FunctionRequirements.builder().valueRequirements(VOL_ID1).build()); assertEquals( test.requirements(ImmutableSet.of(EUR_USD)), FunctionRequirements.builder().valueRequirements(VOL_ID1).build()); assertThrowsIllegalArg(() -> test.requirements(ImmutableSet.of(EUR_GBP))); } public void test_of_map() { ImmutableMap<CurrencyPair, FxOptionVolatilitiesId> ids = ImmutableMap.of(EUR_USD, VOL_ID1, GBP_USD, VOL_ID1); FxOptionMarketDataLookup test = FxOptionMarketDataLookup.of(ids); assertEquals(test.queryType(), FxOptionMarketDataLookup.class); assertEquals(test.getVolatilityCurrencyPairs(), ImmutableSet.of(EUR_USD, GBP_USD)); assertEquals(test.getVolatilityIds(EUR_USD), ImmutableSet.of(VOL_ID1)); assertThrowsIllegalArg(() -> test.getVolatilityIds(EUR_GBP)); assertEquals( test.requirements(EUR_USD), FunctionRequirements.builder().valueRequirements(VOL_ID1).build()); assertEquals( test.requirements(ImmutableSet.of(EUR_USD)), FunctionRequirements.builder().valueRequirements(VOL_ID1).build()); assertThrowsIllegalArg(() -> test.requirements(ImmutableSet.of(EUR_GBP))); assertEquals(test.volatilities(EUR_USD, MOCK_MARKET_DATA), MOCK_VOLS); assertThrowsIllegalArg(() -> test.volatilities(EUR_GBP, MOCK_MARKET_DATA)); } //------------------------------------------------------------------------- public void test_marketDataView() { FxOptionMarketDataLookup test = FxOptionMarketDataLookup.of(EUR_USD, VOL_ID1); LocalDate valDate = date(2015, 6, 30); ScenarioMarketData md = new TestMarketDataMap(valDate, ImmutableMap.of(), ImmutableMap.of()); FxOptionScenarioMarketData multiScenario = test.marketDataView(md); assertEquals(multiScenario.getLookup(), test); assertEquals(multiScenario.getMarketData(), md); assertEquals(multiScenario.getScenarioCount(), 1); FxOptionMarketData scenario = multiScenario.scenario(0); assertEquals(scenario.getLookup(), test); assertEquals(scenario.getMarketData(), md.scenario(0)); assertEquals(scenario.getValuationDate(), valDate); } //------------------------------------------------------------------------- public void coverage() { DefaultFxOptionMarketDataLookup test = DefaultFxOptionMarketDataLookup.of(ImmutableMap.of(EUR_USD, VOL_ID1, GBP_USD, VOL_ID1)); coverImmutableBean(test); DefaultFxOptionMarketDataLookup test2 = DefaultFxOptionMarketDataLookup.of(EUR_USD, VOL_ID1); coverBeanEquals(test, test2); coverImmutableBean((ImmutableBean) test.marketDataView(MOCK_CALC_MARKET_DATA)); coverImmutableBean((ImmutableBean) test.marketDataView(MOCK_MARKET_DATA)); } public void test_serialization() { DefaultFxOptionMarketDataLookup test = DefaultFxOptionMarketDataLookup.of(ImmutableMap.of(EUR_USD, VOL_ID1, GBP_USD, VOL_ID1)); assertSerialization(test); } }