blob: 89bb7e54ac8df26bee31ab27acdfcd4499a1a711 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
/*******************************************************************************
* Copyright (c) 2009, 2011 Mountainminds GmbH & Co. KG and Contributors
* 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:
* Marc R. Hoffmann - initial API and implementation
*
*******************************************************************************/
package org.jacoco.core.test.perf;
import org.jacoco.core.analysis.Analyzer;
import org.jacoco.core.analysis.IClassCoverage;
import org.jacoco.core.analysis.ICoverageVisitor;
import org.jacoco.core.data.ExecutionDataStore;
import org.jacoco.core.test.TargetLoader;
/**
* Scenario to measure the time taken by the instrumentation process itself.
*
* @author Marc R. Hoffmann
* @version $qualified.bundle.version$
*/
public class AnalysisTimeScenario extends TimedScenario {
private final Class<?> target;
private final int count;
protected AnalysisTimeScenario(Class<?> target, int count) {
super(String.format("analysing %s classes", Integer.valueOf(count)));
this.target = target;
this.count = count;
}
@Override
protected Runnable getInstrumentedRunnable() throws Exception {
final byte[] bytes = TargetLoader.getClassDataAsBytes(target);
final ExecutionDataStore executionData = new ExecutionDataStore();
ICoverageVisitor visitor = new ICoverageVisitor() {
public void visitCoverage(IClassCoverage coverage) {
}
};
final Analyzer analyzer = new Analyzer(executionData, visitor);
return new Runnable() {
public void run() {
for (int i = 0; i < count; i++) {
analyzer.analyzeClass(bytes);
}
}
};
}
}
|