diff options
author | Marc R. Hoffmann <hoffmann@mountainminds.com> | 2011-02-11 15:26:19 +0000 |
---|---|---|
committer | Marc R. Hoffmann <hoffmann@mountainminds.com> | 2011-02-11 15:26:19 +0000 |
commit | 82c11be3dd19fc071f87fedc5782c11ca51a0732 (patch) | |
tree | dec4dd7ef6b8ad594bc3f6b78c12a35fc9e91812 /org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java | |
parent | fc417961148de5f05a7d86677a4265d4b91e9c63 (diff) | |
download | jacoco-82c11be3dd19fc071f87fedc5782c11ca51a0732.tar.gz |
Trac #53: Simplified reporting API, step 1.
Diffstat (limited to 'org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java')
-rw-r--r-- | org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java | 92 |
1 files changed, 92 insertions, 0 deletions
diff --git a/org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java b/org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java new file mode 100644 index 00000000..6a5b75c4 --- /dev/null +++ b/org.jacoco.report.test/src/org/jacoco/report/csv/ClassRowWriterTest.java @@ -0,0 +1,92 @@ +/*******************************************************************************
+ * 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.report.csv;
+
+import static org.junit.Assert.assertEquals;
+
+import java.io.BufferedReader;
+import java.io.StringReader;
+import java.io.StringWriter;
+
+import org.jacoco.core.analysis.IClassCoverage;
+import org.jacoco.core.internal.analysis.ClassCoverageImpl;
+import org.jacoco.core.internal.analysis.CounterImpl;
+import org.jacoco.report.ILanguageNames;
+import org.junit.Before;
+import org.junit.Test;
+
+/**
+ * Unit tests for {@link ClassRowWriter}.
+ */
+public class ClassRowWriterTest {
+
+ private StringWriter result;
+
+ private ClassRowWriter writer;
+
+ @Before
+ public void setup() throws Exception {
+ ILanguageNames names = new ILanguageNames() {
+ public String getClassName(String vmname, String vmsignature,
+ String vmsuperclass, String[] vminterfaces) {
+ return vmname;
+ }
+
+ public String getPackageName(String vmname) {
+ return vmname;
+ }
+
+ public String getQualifiedClassName(String vmname) {
+ throw new AssertionError();
+ }
+
+ public String getMethodName(String vmclassname,
+ String vmmethodname, String vmdesc, String vmsignature) {
+ throw new AssertionError();
+ }
+ };
+ result = new StringWriter();
+ writer = new ClassRowWriter(new DelimitedWriter(result), names);
+ }
+
+ @Test
+ public void TestHeader() throws Exception {
+ BufferedReader reader = getResultReader();
+ assertEquals(
+ "GROUP,PACKAGE,CLASS,INSTRUCTION_MISSED,INSTRUCTION_COVERED,BRANCH_MISSED,BRANCH_COVERED,LINE_MISSED,LINE_COVERED,METHOD_MISSED,METHOD_COVERED",
+ reader.readLine());
+ }
+
+ @Test
+ public void TestRow() throws Exception {
+ IClassCoverage node = new ClassCoverageImpl("test/package/Foo", 123,
+ null, "java/lang/Object", null) {
+ {
+ instructionCounter = CounterImpl.getInstance(1, 11);
+ branchCounter = CounterImpl.getInstance(2, 22);
+ lineCounter = CounterImpl.getInstance(3, 33);
+ methodCounter = CounterImpl.getInstance(4, 44);
+ classCounter = CounterImpl.getInstance(5, 55);
+ }
+ };
+ writer.writeRow("group", "test/package", node);
+ BufferedReader reader = getResultReader();
+ reader.readLine();
+ assertEquals("group,test/package,test/package/Foo,1,11,2,22,3,33,4,44",
+ reader.readLine());
+ }
+
+ private BufferedReader getResultReader() {
+ return new BufferedReader(new StringReader(result.toString()));
+ }
+
+}
|