X-Git-Url: https://gerrit.simantics.org/r/gitweb?p=simantics%2Fplatform.git;a=blobdiff_plain;f=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fperformance%2Fread%2FLogTest.java;fp=tests%2Forg.simantics.db.tests%2Fsrc%2Forg%2Fsimantics%2Fdb%2Ftests%2Fperformance%2Fread%2FLogTest.java;h=edbe9ef3da312787aaa5ce34ce10af76327114db;hp=0000000000000000000000000000000000000000;hb=67fd62f9c742337ec80eef658192db198a0efaac;hpb=cde82ba81327d5515fdca362f7f4c70f5103ae80 diff --git a/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/read/LogTest.java b/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/read/LogTest.java new file mode 100644 index 000000000..edbe9ef3d --- /dev/null +++ b/tests/org.simantics.db.tests/src/org/simantics/db/tests/performance/read/LogTest.java @@ -0,0 +1,68 @@ +/******************************************************************************* + * 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.performance.read; + +import java.util.UUID; + +import org.simantics.databoard.Bindings; +import org.simantics.datatypes.utils.LogUtils; +import org.simantics.db.Resource; +import org.simantics.db.Session; +import org.simantics.db.WriteGraph; +import org.simantics.db.common.request.WriteResultRequest; +import org.simantics.db.exception.DatabaseException; +import org.simantics.db.service.VirtualGraphSupport; +import org.simantics.db.testing.base.ExistingDatabaseTest; + + +public class LogTest extends ExistingDatabaseTest { + + public static final int NODE_SIZE = 2; + public static final int TEN = 10; + public static final int THOUSAND = 1000; + public static final int MILLION = 1000000; + + public static final int KEY_SIZE = TEN * 1000; + + public void test() throws Exception { + + Session session = getSession(); + + VirtualGraphSupport vgss = session.getService(VirtualGraphSupport.class); + + long start = System.nanoTime(); + + session.sync(new WriteResultRequest(vgss.getMemoryPersistent(UUID.randomUUID().toString())) { + + @Override + public Resource perform(WriteGraph graph) throws DatabaseException { + + LogUtils lu = new LogUtils(graph); + Resource log = lu.create(graph, NODE_SIZE, 0); + for(int i=0;i