blob: 5d9392d639a295a152f5d61c32e9b11165f17e89 [file] [log] [blame]
/*******************************************************************************
* Copyright (c) 2013, 2015 Ericsson
*
* All rights reserved. This program and the accompanying materials are
* made available under the terms of the Eclipse Public License 2.0 which
* accompanies this distribution, and is available at
* https://www.eclipse.org/legal/epl-2.0/
*
* SPDX-License-Identifier: EPL-2.0
*
* Contributors:
* Alexandre Montplaisir - Initial API and implementation
******************************************************************************/
package org.eclipse.tracecompass.lttng2.kernel.core.tests.analysis.kernel.statesystem;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.List;
import org.eclipse.tracecompass.analysis.os.linux.core.kernel.KernelAnalysisModule;
import org.eclipse.tracecompass.statesystem.core.ITmfStateSystem;
import org.eclipse.tracecompass.statesystem.core.exceptions.StateSystemDisposedException;
import org.eclipse.tracecompass.statesystem.core.interval.ITmfStateInterval;
import org.eclipse.tracecompass.statesystem.core.statevalue.ITmfStateValue;
import org.eclipse.tracecompass.testtraces.ctf.CtfTestTrace;
import org.eclipse.tracecompass.tmf.core.exceptions.TmfAnalysisException;
import org.eclipse.tracecompass.tmf.core.statesystem.TmfStateSystemAnalysisModule;
import org.eclipse.tracecompass.tmf.ctf.core.tests.shared.CtfTmfTestTraceUtils;
import org.eclipse.tracecompass.tmf.ctf.core.trace.CtfTmfTrace;
import org.junit.Test;
/**
* Small program to regenerate the values used in "TestValues.java" from the
* current LTTng-kernel state provider.
*
* It will write its output the a file called 'TestValues<something>.java' in
* your temporary files directory.
*
* @author Alexandre Montplaisir
*/
public class GenerateTestValues {
private static final long TARGET_TIMESTAMP = 18670067372290L + 1331649577946812237L;
private static final String INDENT = " ";
/**
* Test wrapper to run main properly
*
* @throws IOException
* If a file could not be created
* @throws TmfAnalysisException
* if the trace is not valid for this analysis
* @throws StateSystemDisposedException
* if the state system was disposed
*/
@Test
public void test() throws IOException, TmfAnalysisException, StateSystemDisposedException {
/* Prepare the files */
File logFile = File.createTempFile("TestValues", ".java");
try (PrintWriter writer = new PrintWriter(new FileWriter(logFile), true);) {
/* Build and query the state system */
final CtfTmfTrace trace = CtfTmfTestTraceUtils.getTrace(CtfTestTrace.TRACE2);
TmfStateSystemAnalysisModule module = new KernelAnalysisModule() {
@Override
protected String getSsFileName() {
return "test-values";
}
};
assertTrue(module.setTrace(trace));
module.setId("test-values");
module.schedule();
module.waitForCompletion();
ITmfStateSystem ssq = module.getStateSystem();
assertNotNull(ssq);
List<ITmfStateInterval> fullState = ssq.queryFullState(TARGET_TIMESTAMP);
/* Start printing the java file's contents */
writer.println("final class TestValues {");
writer.println();
writer.println(INDENT + "static int size = " + fullState.size() + ";");
writer.println();
/* Print the array contents */
writer.println(INDENT + "static long[] startTimes = {");
for (ITmfStateInterval interval : fullState) {
writer.println(INDENT + INDENT + String.valueOf(interval.getStartTime()) + "L,");
}
writer.println(INDENT + "};");
writer.println();
writer.println(INDENT + "static long[] endTimes = {");
for (ITmfStateInterval interval : fullState) {
writer.println(INDENT + INDENT + String.valueOf(interval.getEndTime()) + "L,");
}
writer.println(INDENT + "};");
writer.println();
writer.println(INDENT + "static ITmfStateValue[] values = {");
for (ITmfStateInterval interval : fullState) {
ITmfStateValue val = interval.getStateValue();
writer.print(INDENT + INDENT);
switch (val.getType()) {
case NULL:
writer.println("TmfStateValue.nullValue(),");
break;
case INTEGER:
writer.println("TmfStateValue.newValueInt(" + val.unboxInt() + "),");
break;
case LONG:
writer.println("TmfStateValue.newValueLong(" + val.unboxLong() + "),");
break;
case DOUBLE:
writer.println("TmfStateValue.newValueDouble(" + val.unboxDouble() + "),");
break;
case STRING:
writer.println("TmfStateValue.newValueString(\"" + val.unboxStr() + "\"),");
break;
case CUSTOM:
default:
writer.println(val.toString());
break;
}
}
writer.println(INDENT + "};");
writer.println("}");
writer.println();
module.dispose();
trace.dispose();
}
System.out.println("wrote to: " + logFile.getAbsolutePath());
}
}