/** * Copyright (C) 2009 - present by OpenGamma Inc. and the OpenGamma group of companies * * Please see distribution for license. */ package com.opengamma.masterdb.historicaltimeseries; import static org.testng.AssertJUnit.assertEquals; import static org.testng.AssertJUnit.assertFalse; import static org.testng.AssertJUnit.assertNotNull; import static org.testng.AssertJUnit.assertTrue; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.jdbc.BadSqlGrammarException; import org.testng.Assert; import org.testng.annotations.Factory; import org.testng.annotations.Test; import org.threeten.bp.Instant; import org.threeten.bp.LocalDate; import com.google.common.collect.Sets; import com.opengamma.DataNotFoundException; import com.opengamma.elsql.ElSqlBundle; import com.opengamma.elsql.ElSqlConfig; import com.opengamma.id.ExternalId; import com.opengamma.id.ExternalIdBundleWithDates; import com.opengamma.id.ExternalIdWithDates; import com.opengamma.id.UniqueId; import com.opengamma.master.historicaltimeseries.HistoricalTimeSeriesInfoDocument; import com.opengamma.master.historicaltimeseries.HistoricalTimeSeriesInfoHistoryRequest; import com.opengamma.master.historicaltimeseries.HistoricalTimeSeriesInfoHistoryResult; import com.opengamma.master.historicaltimeseries.ManageableHistoricalTimeSeriesInfo; import com.opengamma.util.OpenGammaClock; import com.opengamma.util.test.DbTest; import com.opengamma.util.test.TestGroup; /** * Tests DbHistoricalTimeSeriesMaster. */ @Test(groups = TestGroup.UNIT_DB) public class DbHistoricalTimeSeriesMasterWorkerUpdateTest extends AbstractDbHistoricalTimeSeriesMasterWorkerTest { // superclass sets up dummy database private static final Logger s_logger = LoggerFactory.getLogger(DbHistoricalTimeSeriesMasterWorkerUpdateTest.class); @Factory(dataProvider = "databases", dataProviderClass = DbTest.class) public DbHistoricalTimeSeriesMasterWorkerUpdateTest(String databaseType, String databaseVersion) { super(databaseType, databaseVersion); s_logger.info("running testcases for {}", databaseType); } //------------------------------------------------------------------------- @Test(expectedExceptions = IllegalArgumentException.class) public void test_update_nullDocument() { _htsMaster.update(null); } @Test(expectedExceptions = IllegalArgumentException.class) public void test_update_noHistoricalTimeSeriesId() { ManageableHistoricalTimeSeriesInfo info = new ManageableHistoricalTimeSeriesInfo(); info.setName("Updated"); info.setDataField("DF"); info.setDataSource("DS"); info.setDataProvider("DP"); info.setObservationTime("OT"); ExternalIdWithDates id = ExternalIdWithDates.of(ExternalId.of("A", "B"), LocalDate.of(2011, 6, 30), null); ExternalIdBundleWithDates bundle = ExternalIdBundleWithDates.of(id); info.setExternalIdBundle(bundle); HistoricalTimeSeriesInfoDocument doc = new HistoricalTimeSeriesInfoDocument(info); _htsMaster.update(doc); } @Test(expectedExceptions = IllegalArgumentException.class) public void test_update_noHistoricalTimeSeries() { HistoricalTimeSeriesInfoDocument doc = new HistoricalTimeSeriesInfoDocument(); doc.setUniqueId(UniqueId.of("DbHts", "101", "0")); _htsMaster.update(doc); } @Test(expectedExceptions = DataNotFoundException.class) public void test_update_notFound() { ManageableHistoricalTimeSeriesInfo info = new ManageableHistoricalTimeSeriesInfo(); info.setUniqueId(UniqueId.of("DbHts", "0", "0")); info.setName("Updated"); info.setDataField("DF"); info.setDataSource("DS"); info.setDataProvider("DP"); info.setObservationTime("OT"); ExternalIdWithDates id = ExternalIdWithDates.of(ExternalId.of("A", "B"), LocalDate.of(2011, 6, 30), null); ExternalIdBundleWithDates bundle = ExternalIdBundleWithDates.of(id); info.setExternalIdBundle(bundle); HistoricalTimeSeriesInfoDocument doc = new HistoricalTimeSeriesInfoDocument(info); _htsMaster.update(doc); } @Test(expectedExceptions = IllegalArgumentException.class) public void test_update_notLatestVersion() { ManageableHistoricalTimeSeriesInfo info = new ManageableHistoricalTimeSeriesInfo(); info.setUniqueId(UniqueId.of("DbHts", "201", "0")); info.setName("Updated"); info.setDataField("DF"); info.setDataSource("DS"); info.setDataProvider("DP"); info.setObservationTime("OT"); ExternalIdWithDates id = ExternalIdWithDates.of(ExternalId.of("A", "B"), LocalDate.of(2011, 6, 30), null); ExternalIdBundleWithDates bundle = ExternalIdBundleWithDates.of(id); info.setExternalIdBundle(bundle); HistoricalTimeSeriesInfoDocument doc = new HistoricalTimeSeriesInfoDocument(info); _htsMaster.update(doc); } @Test public void test_update_getUpdateGet() { Instant now = Instant.now(_htsMaster.getClock()); HistoricalTimeSeriesInfoDocument base = _htsMaster.get(UniqueId.of("DbHts", "101", "0")); ManageableHistoricalTimeSeriesInfo info = new ManageableHistoricalTimeSeriesInfo(); info.setUniqueId(UniqueId.of("DbHts", "101", "0")); info.setName("Updated"); info.setDataField("DF"); info.setDataSource("DS"); info.setDataProvider("DP"); info.setObservationTime("OT"); ExternalIdWithDates id = ExternalIdWithDates.of(ExternalId.of("A", "B"), LocalDate.of(2011, 6, 30), null); ExternalIdBundleWithDates bundle = ExternalIdBundleWithDates.of(id); info.setExternalIdBundle(bundle); HistoricalTimeSeriesInfoDocument input = new HistoricalTimeSeriesInfoDocument(info); HistoricalTimeSeriesInfoDocument updated = _htsMaster.update(input); assertEquals(false, base.getUniqueId().equals(updated.getUniqueId())); assertEquals(now, updated.getVersionFromInstant()); assertEquals(null, updated.getVersionToInstant()); assertEquals(now, updated.getCorrectionFromInstant()); assertEquals(null, updated.getCorrectionToInstant()); assertEquals(input.getInfo(), updated.getInfo()); HistoricalTimeSeriesInfoDocument old = _htsMaster.get(UniqueId.of("DbHts", "101", "0")); assertEquals(base.getUniqueId(), old.getUniqueId()); assertEquals(base.getVersionFromInstant(), old.getVersionFromInstant()); assertEquals(now, old.getVersionToInstant()); // old version ended assertEquals(base.getCorrectionFromInstant(), old.getCorrectionFromInstant()); assertEquals(base.getCorrectionToInstant(), old.getCorrectionToInstant()); assertEquals(base.getInfo(), old.getInfo()); HistoricalTimeSeriesInfoHistoryRequest search = new HistoricalTimeSeriesInfoHistoryRequest(base.getUniqueId(), null, now); HistoricalTimeSeriesInfoHistoryResult searchResult = _htsMaster.history(search); assertEquals(2, searchResult.getDocuments().size()); } @Test public void test_update_Permission() throws Exception { _htsMaster.setClock(OpenGammaClock.getInstance()); UniqueId baseUniqueId = UniqueId.of("DbHts", "101", "0"); HistoricalTimeSeriesInfoDocument baseDoc = _htsMaster.get(baseUniqueId); assertEquals(baseUniqueId, baseDoc.getUniqueId()); ManageableHistoricalTimeSeriesInfo baseInfo = baseDoc.getValue(); assertEquals(baseUniqueId, baseInfo.getUniqueId()); assertTrue(baseInfo.getRequiredPermissions().isEmpty()); ManageableHistoricalTimeSeriesInfo input = baseInfo.clone(); input.setName("A1"); input.setRequiredPermissions(Sets.newHashSet("A")); Thread.sleep(100); HistoricalTimeSeriesInfoDocument updated = _htsMaster.update(new HistoricalTimeSeriesInfoDocument(input)); ManageableHistoricalTimeSeriesInfo updatedInfo = updated.getValue(); assertFalse(baseDoc.getUniqueId().equals(updated.getUniqueId())); assertEquals(baseInfo.getDataField(), updatedInfo.getDataField()); assertEquals(baseInfo.getDataProvider(), updatedInfo.getDataProvider()); assertEquals(baseInfo.getDataSource(), updatedInfo.getDataSource()); assertEquals(baseInfo.getExternalIdBundle(), updatedInfo.getExternalIdBundle()); assertEquals("A1", updatedInfo.getName()); assertEquals(baseInfo.getObservationTime(), updatedInfo.getObservationTime()); assertEquals(baseInfo.getTimeSeriesObjectId(), updatedInfo.getTimeSeriesObjectId()); assertNotNull(updatedInfo.getRequiredPermissions()); assertEquals(1, updatedInfo.getRequiredPermissions().size()); assertTrue(updatedInfo.getRequiredPermissions().contains("A")); assertEquals(updated, _htsMaster.get(updated.getUniqueId())); input = updatedInfo.clone(); input.setName("A2"); input.setRequiredPermissions(Sets.newHashSet("A", "B")); Thread.sleep(100); updated = _htsMaster.update(new HistoricalTimeSeriesInfoDocument(input)); updatedInfo = updated.getValue(); assertFalse(baseDoc.getUniqueId().equals(updated.getUniqueId())); assertEquals(baseInfo.getDataField(), updatedInfo.getDataField()); assertEquals(baseInfo.getDataProvider(), updatedInfo.getDataProvider()); assertEquals(baseInfo.getDataSource(), updatedInfo.getDataSource()); assertEquals(baseInfo.getExternalIdBundle(), updatedInfo.getExternalIdBundle()); assertEquals("A2", updatedInfo.getName()); assertEquals(baseInfo.getObservationTime(), updatedInfo.getObservationTime()); assertEquals(baseInfo.getTimeSeriesObjectId(), updatedInfo.getTimeSeriesObjectId()); assertNotNull(updatedInfo.getRequiredPermissions()); assertEquals(2, updatedInfo.getRequiredPermissions().size()); assertTrue(updatedInfo.getRequiredPermissions().contains("A")); assertTrue(updatedInfo.getRequiredPermissions().contains("B")); assertEquals(updated, _htsMaster.get(updated.getUniqueId())); HistoricalTimeSeriesInfoHistoryRequest search = new HistoricalTimeSeriesInfoHistoryRequest(baseDoc.getUniqueId(), null, Instant.now(_htsMaster.getClock())); HistoricalTimeSeriesInfoHistoryResult searchResult = _htsMaster.history(search); assertEquals(3, searchResult.getDocuments().size()); } @Test public void test_update_rollback() { DbHistoricalTimeSeriesMaster w = new DbHistoricalTimeSeriesMaster(_htsMaster.getDbConnector()); w.setElSqlBundle(ElSqlBundle.of(new ElSqlConfig("TestRollback"), DbHistoricalTimeSeriesMaster.class)); final HistoricalTimeSeriesInfoDocument base = _htsMaster.get(UniqueId.of("DbHts", "101", "0")); ManageableHistoricalTimeSeriesInfo info = new ManageableHistoricalTimeSeriesInfo(); info.setUniqueId(UniqueId.of("DbHts", "101", "0")); info.setName("Updated"); info.setDataField("DF"); info.setDataSource("DS"); info.setDataProvider("DP"); info.setObservationTime("OT"); ExternalIdWithDates id = ExternalIdWithDates.of(ExternalId.of("A", "B"), LocalDate.of(2011, 6, 30), null); ExternalIdBundleWithDates bundle = ExternalIdBundleWithDates.of(id); info.setExternalIdBundle(bundle); HistoricalTimeSeriesInfoDocument input = new HistoricalTimeSeriesInfoDocument(info); try { w.update(input); Assert.fail(); } catch (BadSqlGrammarException ex) { // expected } final HistoricalTimeSeriesInfoDocument test = _htsMaster.get(UniqueId.of("DbHts", "101", "0")); assertEquals(base, test); } //------------------------------------------------------------------------- @Test public void test_toString() { assertEquals(_htsMaster.getClass().getSimpleName() + "[DbHts]", _htsMaster.toString()); } }