/* * Copyright (C) 2009 eXo Platform SAS. * * This is free software; you can redistribute it and/or modify it * under the terms of the GNU Lesser General Public License as * published by the Free Software Foundation; either version 2.1 of * the License, or (at your option) any later version. * * This software is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this software; if not, write to the Free * Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA * 02110-1301 USA, or see the FSF site: http://www.fsf.org. */ package org.exoplatform.services.jcr.impl.dataflow.serialization; import org.exoplatform.services.jcr.impl.dataflow.SpoolConfig; import org.exoplatform.services.jcr.impl.dataflow.TransientValueData; import org.exoplatform.services.jcr.impl.dataflow.persistent.PersistedValueData; import org.exoplatform.services.jcr.impl.dataflow.persistent.StreamPersistedValueData; import java.io.ByteArrayInputStream; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.IOException; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import java.util.ArrayList; import java.util.Iterator; import java.util.List; import java.util.Random; import javax.jcr.PropertyType; /** * Created by The eXo Platform SAS. <br>Date: * * @author <a href="karpenko.sergiy@gmail.com">Karpenko Sergiy</a> * @version $Id: JCRSerializationVSJavaSerializationTest.java 111 2008-11-11 * 11:11:11Z serg $ */ public class JCRSerializationVSJavaSerializationTestLoad extends JcrImplSerializationBaseTest { private final static int nodes = 1000; private final static int iterations = 50; public void testSerialization() throws Exception { List<PersistedValueData> list = new ArrayList<PersistedValueData>(); // Random random = new Random(); ByteArrayInputStream bin; for (int i = 0; i < nodes; i++) { bin = new ByteArrayInputStream(createBLOBTempData(20)); list.add(new StreamPersistedValueData(0, bin, SpoolConfig.getDefaultSpoolConfig())); } Iterator<PersistedValueData> it; // Serialize with JCR long jcrwrite = 0; long jcrread = 0; for (int j = 0; j < iterations; j++) { it = list.iterator(); File jcrfile = File.createTempFile("jcr", "test"); ObjectWriterImpl jcrout = new ObjectWriterImpl(new FileOutputStream(jcrfile)); long t1 = System.currentTimeMillis(); PersistedValueDataWriter wr = new PersistedValueDataWriter(); while (it.hasNext()) { wr.write(jcrout, it.next()); } t1 = System.currentTimeMillis() - t1; jcrwrite += t1; jcrout.close(); // deserialize ObjectReaderImpl jcrin = new ObjectReaderImpl(new FileInputStream(jcrfile)); long t3 = System.currentTimeMillis(); PersistedValueDataReader rdr = new PersistedValueDataReader(holder, SpoolConfig.getDefaultSpoolConfig()); for (int i = 0; i < nodes; i++) { PersistedValueData obj = rdr.read(jcrin, PropertyType.BINARY); } t3 = System.currentTimeMillis() - t3; jcrread += t3; jcrin.close(); jcrfile.delete(); } // java long javaWrite = 0; long javaRead = 0; for (int j = 0; j < iterations; j++) { File jfile = File.createTempFile("java", "test"); ObjectOutputStream jout = new ObjectOutputStream(new FileOutputStream(jfile)); it = list.iterator(); long t2 = System.currentTimeMillis(); while (it.hasNext()) { jout.writeObject(it.next()); } t2 = System.currentTimeMillis() - t2; javaWrite += t2; jout.close(); // deserialize ObjectInputStream jin = new ObjectInputStream(new FileInputStream(jfile)); it = list.iterator(); long t4 = System.currentTimeMillis(); for (int i = 0; i < nodes; i++) { TransientValueData obj = (TransientValueData)jin.readObject(); } t4 = System.currentTimeMillis() - t4; javaRead += t4; jin.close(); jfile.delete(); } System.out.println(" JCR s- " + (jcrwrite / iterations)); System.out.println(" Java s- " + (javaWrite / iterations)); // System.out.println(" JCR file size - " + jcrfile.length()); // System.out.println(" Java file size - " + jfile.length()); System.out.println(" JCR des- " + (jcrread / iterations)); System.out.println(" Java des- " + (javaRead / iterations)); } protected byte[] createBLOBTempData(int size) throws IOException { byte[] data = new byte[size * 1024]; // 1Kb Random random = new Random(); random.nextBytes(data); return data; } }