blob: 9edc23bb13a0d44d5ada085592998bfc4155d216 [file] [log] [blame]
/**
* Copyright (c) 2012, 2013 itemis AG.
* 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:
* Mark Broerkens - initial API and implementation
*
*/
package org.eclipse.rmf.tests.reqif10.serialization.uc002;
import java.io.File;
import java.math.BigDecimal;
import org.eclipse.core.runtime.IPath;
import org.eclipse.rmf.reqif10.ReqIF;
import org.eclipse.rmf.tests.reqif10.serialization.util.AbstractTestCase;
import org.eclipse.rmf.tests.reqif10.serialization.util.TC9000ModelBuilder;
import org.junit.Test;
@SuppressWarnings("nls")
public class TC9000SimpleContentPerformanceTests extends AbstractTestCase {
private static final String WORKING_DIRECTORY = "work";
@Test
public void testSpecObject() throws Exception {
for (int i = 1; i < 10000; i = i * 2) {
String fileName = "TC9000_SimpleContent_PerformanceTests_SpecObjects_" + i + ".reqif";
ReqIF reqif = new TC9000ModelBuilder(null, "ID_" + fileName, fileName, i).getReqIF();
saveReqIFFile(reqif, WORKING_DIRECTORY + IPath.SEPARATOR + fileName);
doTest(fileName);
}
}
private void doTest(String filename) throws Exception {
System.out.println("Loading '" + filename + "'...");
long totaltime = 0;
for (int i = 0; i < 3; i++) {
long start = System.currentTimeMillis();
loadReqIFFile(WORKING_DIRECTORY + IPath.SEPARATOR + filename);
long end = System.currentTimeMillis();
totaltime += end - start;
}
double size = new File(WORKING_DIRECTORY + IPath.SEPARATOR + filename).length() / 1024;
double avgtime = totaltime / 3;
double timeperkb = new BigDecimal(avgtime / size).setScale(3, BigDecimal.ROUND_UP).doubleValue();
System.out.println("Avg. time taken for '" + filename + "' with size " + size + "KB: " + avgtime / 1000 + "s");
System.out.println("Time per KB: " + timeperkb + "ms");
}
}