Search in sources :

Example 1 with LoggerRuntime

use of org.jacoco.core.runtime.LoggerRuntime in project jacoco by jacoco.

the class CoreTutorial method execute.

/**
 * Run this example.
 *
 * @throws Exception
 *             in case of errors
 */
public void execute() throws Exception {
    final String targetName = TestTarget.class.getName();
    // For instrumentation and runtime we need a IRuntime instance
    // to collect execution data:
    final IRuntime runtime = new LoggerRuntime();
    // The Instrumenter creates a modified version of our test target class
    // that contains additional probes for execution data recording:
    final Instrumenter instr = new Instrumenter(runtime);
    InputStream original = getTargetClass(targetName);
    final byte[] instrumented = instr.instrument(original, targetName);
    original.close();
    // Now we're ready to run our instrumented class and need to startup the
    // runtime first:
    final RuntimeData data = new RuntimeData();
    runtime.startup(data);
    // In this tutorial we use a special class loader to directly load the
    // instrumented class definition from a byte[] instances.
    final MemoryClassLoader memoryClassLoader = new MemoryClassLoader();
    memoryClassLoader.addDefinition(targetName, instrumented);
    final Class<?> targetClass = memoryClassLoader.loadClass(targetName);
    // Here we execute our test target class through its Runnable interface:
    final Runnable targetInstance = (Runnable) targetClass.newInstance();
    targetInstance.run();
    // At the end of test execution we collect execution data and shutdown
    // the runtime:
    final ExecutionDataStore executionData = new ExecutionDataStore();
    final SessionInfoStore sessionInfos = new SessionInfoStore();
    data.collect(executionData, sessionInfos, false);
    runtime.shutdown();
    // Together with the original class definition we can calculate coverage
    // information:
    final CoverageBuilder coverageBuilder = new CoverageBuilder();
    final Analyzer analyzer = new Analyzer(executionData, coverageBuilder);
    original = getTargetClass(targetName);
    analyzer.analyzeClass(original, targetName);
    original.close();
    // Let's dump some metrics and line coverage information:
    for (final IClassCoverage cc : coverageBuilder.getClasses()) {
        out.printf("Coverage of class %s%n", cc.getName());
        printCounter("instructions", cc.getInstructionCounter());
        printCounter("branches", cc.getBranchCounter());
        printCounter("lines", cc.getLineCounter());
        printCounter("methods", cc.getMethodCounter());
        printCounter("complexity", cc.getComplexityCounter());
        for (int i = cc.getFirstLine(); i <= cc.getLastLine(); i++) {
            out.printf("Line %s: %s%n", Integer.valueOf(i), getColor(cc.getLine(i).getStatus()));
        }
    }
}
Also used : RuntimeData(org.jacoco.core.runtime.RuntimeData) LoggerRuntime(org.jacoco.core.runtime.LoggerRuntime) InputStream(java.io.InputStream) CoverageBuilder(org.jacoco.core.analysis.CoverageBuilder) Analyzer(org.jacoco.core.analysis.Analyzer) IRuntime(org.jacoco.core.runtime.IRuntime) ExecutionDataStore(org.jacoco.core.data.ExecutionDataStore) IClassCoverage(org.jacoco.core.analysis.IClassCoverage) Instrumenter(org.jacoco.core.instr.Instrumenter) SessionInfoStore(org.jacoco.core.data.SessionInfoStore)

Example 2 with LoggerRuntime

use of org.jacoco.core.runtime.LoggerRuntime in project jacoco by jacoco.

the class InstrumentationSizeSzenario method run.

public void run(IPerfOutput output) throws Exception {
    final IRuntime runtime = new LoggerRuntime();
    ClassReader reader = new ClassReader(TargetLoader.getClassData(target));
    final Instrumenter instr = new Instrumenter(runtime);
    instr.instrument(reader);
    output.writeByteResult("instrumented class", instr.instrument(reader).length, reader.b.length);
}
Also used : LoggerRuntime(org.jacoco.core.runtime.LoggerRuntime) ClassReader(org.objectweb.asm.ClassReader) Instrumenter(org.jacoco.core.instr.Instrumenter) IRuntime(org.jacoco.core.runtime.IRuntime)

Example 3 with LoggerRuntime

use of org.jacoco.core.runtime.LoggerRuntime in project powermock by powermock.

the class JacocoCoverageTest method runTargetTest.

private void runTargetTest(RuntimeData data) throws Exception {
    IRuntime runtime = new LoggerRuntime();
    instrumentClasses(runtime);
    runtime.startup(data);
    JUnitCore.runClasses(TargetTest.class);
    runtime.shutdown();
    restoreOriginalClasses();
}
Also used : LoggerRuntime(org.jacoco.core.runtime.LoggerRuntime) IRuntime(org.jacoco.core.runtime.IRuntime)

Example 4 with LoggerRuntime

use of org.jacoco.core.runtime.LoggerRuntime in project jacoco by jacoco.

the class ExecuteInstrumentedCodeScenario method getInstrumentedCallable.

@Override
@SuppressWarnings("unchecked")
protected Callable<Void> getInstrumentedCallable() throws Exception {
    ClassReader reader = new ClassReader(TargetLoader.getClassData(target));
    IRuntime runtime = new LoggerRuntime();
    runtime.startup(new RuntimeData());
    final Instrumenter instr = new Instrumenter(runtime);
    final byte[] instrumentedBuffer = instr.instrument(reader);
    final TargetLoader loader = new TargetLoader();
    return (Callable<Void>) loader.add(target, instrumentedBuffer).newInstance();
}
Also used : RuntimeData(org.jacoco.core.runtime.RuntimeData) LoggerRuntime(org.jacoco.core.runtime.LoggerRuntime) TargetLoader(org.jacoco.core.test.TargetLoader) ClassReader(org.objectweb.asm.ClassReader) Instrumenter(org.jacoco.core.instr.Instrumenter) Callable(java.util.concurrent.Callable) IRuntime(org.jacoco.core.runtime.IRuntime)

Example 5 with LoggerRuntime

use of org.jacoco.core.runtime.LoggerRuntime in project jacoco by jacoco.

the class InstrumentationTimeScenario method getInstrumentedCallable.

@Override
protected Callable<Void> getInstrumentedCallable() throws Exception {
    final byte[] bytes = TargetLoader.getClassDataAsBytes(target);
    final Instrumenter instr = new Instrumenter(new LoggerRuntime());
    return new Callable<Void>() {

        public Void call() throws Exception {
            for (int i = 0; i < count; i++) {
                instr.instrument(bytes, "TestTarget");
            }
            return null;
        }
    };
}
Also used : LoggerRuntime(org.jacoco.core.runtime.LoggerRuntime) Instrumenter(org.jacoco.core.instr.Instrumenter) Callable(java.util.concurrent.Callable)

Aggregations

LoggerRuntime (org.jacoco.core.runtime.LoggerRuntime)5 Instrumenter (org.jacoco.core.instr.Instrumenter)4 IRuntime (org.jacoco.core.runtime.IRuntime)4 Callable (java.util.concurrent.Callable)2 RuntimeData (org.jacoco.core.runtime.RuntimeData)2 ClassReader (org.objectweb.asm.ClassReader)2 InputStream (java.io.InputStream)1 Analyzer (org.jacoco.core.analysis.Analyzer)1 CoverageBuilder (org.jacoco.core.analysis.CoverageBuilder)1 IClassCoverage (org.jacoco.core.analysis.IClassCoverage)1 ExecutionDataStore (org.jacoco.core.data.ExecutionDataStore)1 SessionInfoStore (org.jacoco.core.data.SessionInfoStore)1 TargetLoader (org.jacoco.core.test.TargetLoader)1