X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fapi%2Fsupport%2FclusterControl%2FCreateAndCollectBigClusterInUpdateTest.java;fp=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fapi%2Fsupport%2FclusterControl%2FCreateAndCollectBigClusterInUpdateTest.java;h=66d80f6baf1010ab16d35b1a708b6e0db4ed2da1;hb=67fd62f9c742337ec80eef658192db198a0efaac;hp=0000000000000000000000000000000000000000;hpb=cde82ba81327d5515fdca362f7f4c70f5103ae80;p=simantics%2Fplatform.git diff --git a/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/support/clusterControl/CreateAndCollectBigClusterInUpdateTest.java b/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/support/clusterControl/CreateAndCollectBigClusterInUpdateTest.java new file mode 100644 index 000000000..66d80f6ba --- /dev/null +++ b/tests/org.simantics.db.tests/src/org/simantics/db/tests/api/support/clusterControl/CreateAndCollectBigClusterInUpdateTest.java @@ -0,0 +1,87 @@ +/******************************************************************************* + * Copyright (c) 2007, 2010 Association for Decentralized Information Management + * in Industry THTH ry. + * All rights reserved. This program and the accompanying materials + * are made available under the terms of the Eclipse Public License v1.0 + * which accompanies this distribution, and is available at + * http://www.eclipse.org/legal/epl-v10.html + * + * Contributors: + * VTT Technical Research Centre of Finland - initial API and implementation + *******************************************************************************/ +package org.simantics.db.tests.api.support.clusterControl; + +import java.util.Arrays; + +import org.junit.Test; +import org.simantics.databoard.Bindings; +import org.simantics.db.Resource; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.request.WriteRequest; +import org.simantics.db.event.ChangeEvent; +import org.simantics.db.event.ChangeListener; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.service.ClusterControl; +import org.simantics.db.service.GraphChangeListenerSupport; +import org.simantics.db.testing.cases.FreshDatabaseTest; + +public class CreateAndCollectBigClusterInUpdateTest extends FreshDatabaseTest { + + Resource resource1; + Resource resource2; + Resource resource3; + + @Test + public void test() throws Exception{ + + GraphChangeListenerSupport changeListenerSupport = getSession().getService(GraphChangeListenerSupport.class); + changeListenerSupport.addMetadataListener( new ChangeListener() { + + @Override + public void graphChanged(ChangeEvent e) throws DatabaseException { + + // Collect + ClusterControl cc = e.getGraph().getService(ClusterControl.class); + cc.collectClusters(Integer.MAX_VALUE); + + Arrays.equals(testArray(10), (byte[])e.getGraph().getValue(resource1, Bindings.BYTE_ARRAY)); + Arrays.equals(testArray(100000), (byte[])e.getGraph().getValue(resource2, Bindings.BYTE_ARRAY)); + Arrays.equals(testArray(10), (byte[])e.getGraph().getValue(resource3, Bindings.BYTE_ARRAY)); + + } + + } ); + + + getSession().sync(new WriteRequest() { + + @Override + public void perform(WriteGraph g) throws DatabaseException { + + g.flushCluster(); + + for(int i=0;i<1000;i++) g.newResource(); + resource1 = g.newResource(); + g.claimValue(resource1, testArray(10), Bindings.BYTE_ARRAY); + + for(int i=0;i<1000;i++) g.newResource(); + resource2 = g.newResource(); + g.claimValue(resource2, testArray(100000), Bindings.BYTE_ARRAY); + + for(int i=0;i<1000;i++) g.newResource(); + resource3 = g.newResource(); + g.claimValue(resource3, testArray(10), Bindings.BYTE_ARRAY); + + } + + }); + + } + + byte[] testArray(int size) { + byte[] result = new byte[size]; + for(int i=0;i