/** * Licensed to the Austrian Association for Software Tool Integration (AASTI) * under one or more contributor license agreements. See the NOTICE file * distributed with this work for additional information regarding copyright * ownership. The AASTI licenses this file to you under the Apache License, * Version 2.0 (the "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.openengsb.core.ekb.persistence.persist.edb; import static org.hamcrest.CoreMatchers.is; import static org.junit.Assert.assertThat; import org.junit.Test; import org.openengsb.core.api.model.OpenEngSBModel; import org.openengsb.core.ekb.api.EKBCommit; import org.openengsb.core.ekb.api.EKBException; import org.openengsb.core.ekb.persistence.persist.edb.internal.EOMode; import org.openengsb.core.ekb.persistence.persist.edb.models.EngineeringObjectModel; import org.openengsb.core.ekb.persistence.persist.edb.models.SourceModelA; import org.openengsb.core.ekb.persistence.persist.edb.models.SourceModelB; public class EOEnhancerTestFullActivatedMode extends AbstractEngineeringObjectEnhancerTest { public EOEnhancerTestFullActivatedMode() { super(EOMode.FULLY_ACTIVATED); } @Test public void testIfEngineeringObjectModelInsertionWorks_shouldLoadTheValuesOfTheForeignKeys() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setModelAId("objectA/reference/1"); model.setModelBId("objectB/reference/1"); EKBCommit commit = getTestCommit().addInsert(model); enhancer.onPreCommit(commit); assertThat(model.getNameA(), is("firstObject")); assertThat(model.getNameB(), is("secondObject")); } @Test public void testIfNormalObjectUpdateTriggersEOUpdate_shouldUpdateAlsoEO() throws Exception { SourceModelA model = new SourceModelA(); model.setNameA("updatedFirstObject"); model.setId("objectA/reference/1"); EKBCommit commit = getTestCommit().addUpdate(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); Object inserted = commit.getUpdates().get(commit.getUpdates().size() - 1); EngineeringObjectModel result = (EngineeringObjectModel) inserted; assertThat(before < after, is(true)); assertThat(result.getNameA(), is("updatedFirstObject")); } @Test public void testIfDoubleNormalObjectUpdateTriggersEOUpdate_shouldUpdateAlsoEO() throws Exception { SourceModelA modelA = new SourceModelA(); modelA.setNameA("updatedFirstObject"); modelA.setId("objectA/reference/1"); SourceModelB modelb = new SourceModelB(); modelb.setNameB("updatedSecondObject"); modelb.setId("objectB/reference/1"); EKBCommit commit = getTestCommit().addUpdate(modelA).addUpdate(modelb); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); Object inserted = commit.getUpdates().get(commit.getUpdates().size() - 1); EngineeringObjectModel result = (EngineeringObjectModel) inserted; assertThat(before < after, is(true)); assertThat(result.getNameA(), is("updatedFirstObject")); assertThat(result.getNameB(), is("updatedSecondObject")); } @Test(expected = EKBException.class) public void testIfTheEngineeringObjectUpdateIsCheckedCorrectly_shouldNotAllowReferenceAndValueChange() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/1"); model.setModelAId("objectA/reference/2"); model.setNameA("teststring"); EKBCommit commit = getTestCommit().addUpdate(model); enhancer.onPreCommit(commit); } @Test public void testIfTheEngineeringObjectReferenceUpdateWorks_shouldLoadOtherModelAndMergeIt() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/1"); model.setModelAId("objectA/reference/2"); model.setModelBId("objectB/reference/1"); model.setNameA("firstObject"); model.setNameB("secondObject"); EKBCommit commit = getTestCommit().addUpdate(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); Object inserted = commit.getUpdates().get(commit.getUpdates().size() - 1); EngineeringObjectModel result = (EngineeringObjectModel) inserted; assertThat(before == after, is(true)); assertThat(result.getNameA(), is("updatedFirstObject")); assertThat(result.getNameB(), is("secondObject")); } @Test public void testIfTheEngineeringObjectReferencesUpdateWorks_shouldLoadOtherModelAndMergeIt() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/1"); model.setModelAId("objectA/reference/2"); model.setModelBId("objectB/reference/2"); model.setNameA("firstObject"); model.setNameB("secondObject"); EKBCommit commit = getTestCommit().addUpdate(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); Object inserted = commit.getUpdates().get(commit.getUpdates().size() - 1); EngineeringObjectModel result = (EngineeringObjectModel) inserted; assertThat(before == after, is(true)); assertThat(result.getNameA(), is("updatedFirstObject")); assertThat(result.getNameB(), is("updatedSecondObject")); } @Test public void testIfEngineeringObjectUpdateAlsoUpdatesReferencedModels_shouldUpdateAllNeededModels() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/1"); model.setModelAId("objectA/reference/1"); model.setModelBId("objectB/reference/1"); model.setNameA("updatedFirstObject"); model.setNameB("updatedSecondObject"); EKBCommit commit = getTestCommit().addUpdate(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); assertThat(after - before == 2, is(true)); SourceModelA modelA = null; SourceModelB modelB = null; for (OpenEngSBModel update : commit.getUpdates()) { if (update.retrieveModelName().equals(SourceModelA.class.getName())) { modelA = (SourceModelA) update; } if (update.retrieveModelName().equals(SourceModelB.class.getName())) { modelB = (SourceModelB) update; } } assertThat(modelA.getNameA(), is("updatedFirstObject")); assertThat(modelB.getNameB(), is("updatedSecondObject")); } @Test public void testIfEOObjectWithNoReferenceCanBeCommitted_shouldWork() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/1"); EKBCommit commit = getTestCommit().addInsert(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); assertThat(after, is(before)); } @Test public void testIfEngineeringObjectUpdateAlsoUpdatesReferencedModel_shouldUpdateNeededModel() throws Exception { EngineeringObjectModel model = new EngineeringObjectModel(); model.setInternalModelName("common/reference/2"); model.setModelAId("objectA/reference/1"); model.setNameA("updatedFirstObject"); EKBCommit commit = getTestCommit().addUpdate(model); int before = commit.getUpdates().size(); enhancer.onPreCommit(commit); int after = commit.getUpdates().size(); assertThat(after - before == 1, is(true)); SourceModelA modelA = null; for (OpenEngSBModel update : commit.getUpdates()) { if (update.retrieveModelName().equals(SourceModelA.class.getName())) { modelA = (SourceModelA) update; } } assertThat(modelA.getNameA(), is("updatedFirstObject")); } }