aboutsummaryrefslogtreecommitdiffstats
path: root/testing
diff options
context:
space:
mode:
authorAndy Clement <aclement@pivotal.io>2020-08-16 11:31:18 -0700
committerAndy Clement <aclement@pivotal.io>2020-08-16 11:31:18 -0700
commite0adab7d8f01c38ef2650a9f726be4ac853ee721 (patch)
treede4823c0fe628530c2867e476718830a85fa8b26 /testing
parent4a2ecf60ebaa4a5ad097da45ef912e1af3cd0dce (diff)
downloadaspectj-e0adab7d8f01c38ef2650a9f726be4ac853ee721.tar.gz
aspectj-e0adab7d8f01c38ef2650a9f726be4ac853ee721.zip
polish
Diffstat (limited to 'testing')
-rw-r--r--testing/src/test/java/org/aspectj/testing/harness/bridge/IncCompilerRun.java148
-rw-r--r--testing/src/test/java/org/aspectj/testing/util/Diffs.java73
-rw-r--r--testing/src/test/java/org/aspectj/testing/util/TestDiffs.java170
3 files changed, 197 insertions, 194 deletions
diff --git a/testing/src/test/java/org/aspectj/testing/harness/bridge/IncCompilerRun.java b/testing/src/test/java/org/aspectj/testing/harness/bridge/IncCompilerRun.java
index e3bbb9209..8ec74ea0b 100644
--- a/testing/src/test/java/org/aspectj/testing/harness/bridge/IncCompilerRun.java
+++ b/testing/src/test/java/org/aspectj/testing/harness/bridge/IncCompilerRun.java
@@ -1,14 +1,14 @@
/* *******************************************************************
- * Copyright (c) 1999-2001 Xerox Corporation,
+ * Copyright (c) 1999-2001 Xerox Corporation,
* 2002 Palo Alto Research Center, Incorporated (PARC).
- * 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:
- * Xerox/PARC initial implementation
+ * 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:
+ * Xerox/PARC initial implementation
* ******************************************************************/
package org.aspectj.testing.harness.bridge;
@@ -28,6 +28,8 @@ import org.aspectj.testing.run.IRunStatus;
import org.aspectj.testing.run.WrappedRunIterator;
import org.aspectj.testing.util.StructureModelUtil;
import org.aspectj.testing.util.StructureModelUtil.ModelIncorrectException;
+import org.aspectj.testing.xml.AjcSpecXmlReader;
+import org.aspectj.testing.xml.IXmlWritable;
import org.aspectj.testing.xml.SoftMessage;
import org.aspectj.testing.xml.XMLWriter;
import org.aspectj.util.FileUtil;
@@ -39,11 +41,11 @@ import org.aspectj.util.LangUtil;
* The staging directory is updated by prefix/suffix rules applied
* to files found below Sandbox.testBaseSrcDir.
* Files with suffix .{tag}.java are owned by this run
- * and are copied to the staging directory
+ * and are copied to the staging directory
* unless they are prefixed "delete.", in which case the
* corresponding file is deleted. Any "owned" file is passed to
* the compiler as the list of changed files.
- * The files entry contains the expected files recompiled. XXX underinclusive
+ * The files entry contains the expected files recompiled. XXX underinclusive
* XXX prefer messages for expected files?
* XXX later: also support specified paths, etc.
*/
@@ -51,7 +53,7 @@ public class IncCompilerRun implements IAjcRun {
final Spec spec; // nonfinal later to make re-runnable
Sandbox sandbox;
-
+
/**
* @param handler must not be null, but may be reused in the same thread
*/
@@ -60,7 +62,7 @@ public class IncCompilerRun implements IAjcRun {
this.spec = spec;
}
- /**
+ /**
* Initialize this from the sandbox, using compiler and changedFiles.
* @param sandbox the Sandbox setup for this test, including copying
* any changed files, etc.
@@ -85,14 +87,14 @@ public class IncCompilerRun implements IAjcRun {
this.sandbox = sandbox;
return doStaging(validator);
}
-
- /**
+
+ /**
* Handle copying and deleting of files per tag.
- * This returns false unless
+ * This returns false unless
* (1) tag is "same", or
* (2) some file was copied or deleted successfully
* and there were no failures copying or deleting files.
- * @return true if staging completed successfully
+ * @return true if staging completed successfully
*/
boolean doStaging(final Validator validator) {
if ("same".equals(spec.tag)) {
@@ -106,7 +108,7 @@ public class IncCompilerRun implements IAjcRun {
// deleting any with ChangedFilesCollector.DELETE_SUFFIX
// sigh - delay until after last last-mod-time
intHolder holder = new intHolder();
- List copied = new ArrayList();
+ List<File> copied = new ArrayList<>();
doStaging(validator,".java",holder,copied);
doStaging(validator,".jar",holder,copied);
doStaging(validator,".class",holder,copied);
@@ -118,7 +120,7 @@ public class IncCompilerRun implements IAjcRun {
result = (0 == holder.numFails);
}
if (0 < copied.size()) {
- File[] files = (File[]) copied.toArray(new File[0]);
+ File[] files = copied.toArray(new File[0]);
FileUtil.sleepPastFinalModifiedTime(files);
}
} catch (NullPointerException npe) {
@@ -129,8 +131,8 @@ public class IncCompilerRun implements IAjcRun {
return result;
}
-
- private void doStaging(final Validator validator, final String toSuffix,
+
+ private void doStaging(final Validator validator, final String toSuffix,
final intHolder holder,final List copied)
throws IOException
{
@@ -165,7 +167,7 @@ public class IncCompilerRun implements IAjcRun {
File destDir = sandbox.stagingDir;
FileUtil.copyDir(srcDir, destDir, fromSuffix, toSuffix, deleteOrCount);
}
-
+
private static class intHolder {
int numCopies;
int numDeletes;
@@ -181,7 +183,7 @@ public class IncCompilerRun implements IAjcRun {
if (null == compiler) {
MessageUtil.abort(status, "null compiler");
}
-
+
// // This is a list of expected classes (in File-normal form
// // relative to base class/src dir, without .class suffix
// // -- like "org/aspectj/tools/ajc/Main")
@@ -192,12 +194,12 @@ public class IncCompilerRun implements IAjcRun {
// }
//
// // now add any (additional) expected-class entries listed in the spec
-// // normalize to a similar file path (and do info messages for redundancies).
+// // normalize to a similar file path (and do info messages for redundancies).
//
// List alsoChanged = spec.getPathsAsFile(sandbox.stagingDir);
// for (Iterator iter = alsoChanged.iterator(); iter.hasNext();) {
// File f = (File) iter.next();
-//
+//
// if (expectedClasses.contains(f)) {
// // XXX remove old comment changed.contains() works b/c getPathsAsFile producing both File
// // normalizes the paths, and File.equals(..) compares these lexically
@@ -205,20 +207,20 @@ public class IncCompilerRun implements IAjcRun {
// MessageUtil.info(status, s + f);
// } else {
// expectedClasses.add(f);
-// }
+// }
// }
-//
+//
// // now can create handler, use it for reporting
// List errors = spec.getMessages(IMessage.ERROR);
// List warnings = spec.getMessages(IMessage.WARNING);
// AjcMessageHandler handler = new AjcMessageHandler(errors, warnings, expectedClasses);
-
- // same DirChanges handling for JavaRun, CompilerRun, IncCompilerRun
+
+ // same DirChanges handling for JavaRun, CompilerRun, IncCompilerRun
// XXX around advice or template method/class
DirChanges dirChanges = null;
if (!LangUtil.isEmpty(spec.dirChanges)) {
LangUtil.throwIaxIfFalse(1 == spec.dirChanges.size(), "expecting only 1 dirChanges");
- dirChanges = new DirChanges((DirChanges.Spec) spec.dirChanges.get(0));
+ dirChanges = new DirChanges(spec.dirChanges.get(0));
if (!dirChanges.start(status, sandbox.classesDir)) {
return false; // setup failed
}
@@ -251,9 +253,9 @@ public class IncCompilerRun implements IAjcRun {
} else {
result = (commandResult == handler.expectingCommandTrue());
if (! result) {
- String m = commandResult
+ String m = commandResult
? "incremental compile command did not return false as expected"
- : "incremental compile command returned false unexpectedly";
+ : "incremental compile command returned false unexpectedly";
MessageUtil.fail(status, m);
} else if (null != dirChanges) {
result = dirChanges.end(status, sandbox.testBaseDir);
@@ -270,9 +272,9 @@ public class IncCompilerRun implements IAjcRun {
}
// XXX weak - actual messages not reported in real-time, no fast-fail
if (report) {
- handler.report(status);
+ handler.report(status);
}
- }
+ }
return result;
}
@@ -282,45 +284,45 @@ public class IncCompilerRun implements IAjcRun {
public String toString() {
- return "" + spec;
+ return "" + spec;
// return "IncCompilerRun(" + spec + ")"; // XXX
}
- /**
+ /**
* initializer/factory for IncCompilerRun.
*/
public static class Spec extends AbstractRunSpec {
public static final String XMLNAME = "inc-compile";
protected boolean fresh;
- protected ArrayList classesAdded;
- protected ArrayList classesRemoved;
- protected ArrayList classesUpdated;
-
+ protected ArrayList<String> classesAdded;
+ protected ArrayList<String> classesRemoved;
+ protected ArrayList<String> classesUpdated;
+
protected String checkModel;
/**
- * skip description, skip sourceLocation,
+ * skip description, skip sourceLocation,
* do keywords, skip options, do paths as classes, do comment,
* skip staging (always true), skip badInput (irrelevant)
- * do dirChanges, do messages but skip children.
+ * do dirChanges, do messages but skip children.
*/
// private static final XMLNames NAMES = new XMLNames(XMLNames.DEFAULT,
// "", "", null, "", "classes", null, "", "", false, false, true);
-//
+//
/** identifies files this run owns, so {name}.{tag}.java maps to {name}.java */
String tag;
public Spec() {
super(XMLNAME);
setStaging(true);
- classesAdded = new ArrayList();
- classesRemoved = new ArrayList();
- classesUpdated = new ArrayList();
+ classesAdded = new ArrayList<>();
+ classesRemoved = new ArrayList<>();
+ classesUpdated = new ArrayList<>();
checkModel="";
}
-
- protected void initClone(Spec spec)
+
+ protected void initClone(Spec spec)
throws CloneNotSupportedException {
super.initClone(spec);
spec.fresh = fresh;
@@ -332,30 +334,30 @@ public class IncCompilerRun implements IAjcRun {
spec.classesUpdated.clear();
spec.classesUpdated.addAll(classesUpdated);
}
-
+
public Object clone() throws CloneNotSupportedException {
Spec result = new Spec();
initClone(result);
- return result;
+ return result;
}
public void setFresh(boolean fresh) {
this.fresh = fresh;
}
-
+
public void setTag(String input) {
tag = input;
}
-
+
public void setCheckModel(String thingsToCheck) {
this.checkModel=thingsToCheck;
}
-
+
public String toString() {
return "IncCompile.Spec(" + tag + ", " + super.toString() + ",["+checkModel+"])";
}
-
+
/** override to set dirToken to Sandbox.CLASSES and default suffix to ".class" */
public void addDirChanges(DirChanges.Spec spec) { // XXX copy/paste of CompilerRun.Spec...
if (null == spec) {
@@ -365,7 +367,7 @@ public class IncCompilerRun implements IAjcRun {
spec.setDefaultSuffix(".class");
super.addDirChanges(spec);
}
-
+
/** @return a IncCompilerRun with this as spec if setup completes successfully. */
public IRunIterator makeRunIterator(Sandbox sandbox, Validator validator) {
IncCompilerRun run = new IncCompilerRun(this);
@@ -375,12 +377,12 @@ public class IncCompilerRun implements IAjcRun {
}
return null;
}
-
- /**
+
+ /**
* Write this out as a compile element as defined in
* AjcSpecXmlReader.DOCTYPE.
- * @see AjcSpecXmlReader#DOCTYPE
- * @see IXmlWritable#writeXml(XMLWriter)
+ * @see AjcSpecXmlReader#DOCTYPE
+ * @see IXmlWritable#writeXml(XMLWriter)
*/
public void writeXml(XMLWriter out) {
String attr = XMLWriter.makeAttribute("tag", tag);
@@ -396,20 +398,20 @@ public class IncCompilerRun implements IAjcRun {
SoftMessage.writeXml(out, getMessages());
out.endElement(xmlElementName);
}
-
+
public void setClassesAdded(String items) {
addItems(classesAdded, items);
}
-
+
public void setClassesUpdated(String items) {
addItems(classesUpdated, items);
}
-
+
public void setClassesRemoved(String items) {
addItems(classesRemoved, items);
}
-
- private void addItems(List list, String items) {
+
+ private void addItems(List<String> list, String items) {
if (null != items) {
String[] classes = XMLWriter.unflattenList(items);
if (!LangUtil.isEmpty(classes)) {
@@ -419,13 +421,13 @@ public class IncCompilerRun implements IAjcRun {
}
}
}
- }
+ }
}
} // class IncCompilerRun.Spec
}
// // XXX replaced with method-local class - revisit if useful
-//
-// /**
+//
+// /**
// * This class collects the list of all changed files and
// * deletes the corresponding file for those prefixed "delete."
// */
@@ -436,7 +438,7 @@ public class IncCompilerRun implements IAjcRun {
// final Validator validator;
// /** need this to generate paths by clipping */
// final File destDir;
-//
+//
// /** @param changed the sink for all files changed (full paths) */
// public ChangedFilesCollector(ArrayList changed, File destDir, Validator validator) {
// LangUtil.throwIaxIfNull(validator, "ChangedFilesCollector - handler");
@@ -446,11 +448,11 @@ public class IncCompilerRun implements IAjcRun {
// }
//
// /**
-// * This converts the input File to normal String path form
+// * This converts the input File to normal String path form
// * (without any source suffix) and adds it to the list changed.
// * If the name of the file is suffixed ".delete..", then
-// * delete the corresponding file, and return false (no copy).
-// * Return true otherwise (copy file).
+// * delete the corresponding file, and return false (no copy).
+// * Return true otherwise (copy file).
// * @see java.io.FileFilter#accept(File)
// */
// public boolean accept(File file) {
@@ -484,9 +486,9 @@ public class IncCompilerRun implements IAjcRun {
// } else {
// int loc = name.lastIndexOf(path);
// if (-1 == loc) { // sigh
-//
+//
// } else {
-//
+//
// }
// }
// }
diff --git a/testing/src/test/java/org/aspectj/testing/util/Diffs.java b/testing/src/test/java/org/aspectj/testing/util/Diffs.java
index 43739b752..acefa78c8 100644
--- a/testing/src/test/java/org/aspectj/testing/util/Diffs.java
+++ b/testing/src/test/java/org/aspectj/testing/util/Diffs.java
@@ -1,14 +1,14 @@
/* *******************************************************************
- * Copyright (c) 1999-2001 Xerox Corporation,
+ * Copyright (c) 1999-2001 Xerox Corporation,
* 2002 Palo Alto Research Center, Incorporated (PARC).
- * 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:
- * Xerox/PARC initial implementation
+ * 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:
+ * Xerox/PARC initial implementation
* ******************************************************************/
package org.aspectj.testing.util;
@@ -26,11 +26,12 @@ import org.aspectj.bridge.IMessage;
import org.aspectj.bridge.IMessageHandler;
import org.aspectj.bridge.ISourceLocation;
import org.aspectj.bridge.MessageUtil;
+import org.aspectj.testing.util.TestDiffs.TestResult;
import org.aspectj.util.FileUtil;
import org.aspectj.util.LangUtil;
-/**
- * Result struct for expected/actual diffs for Collection
+/**
+ * Result struct for expected/actual diffs for Collection
*/
public class Diffs {
@@ -76,8 +77,8 @@ public class Diffs {
* @throws NullPointerException if anything is null
*/
public int compare(IMessage lhs, IMessage rhs) {
- IMessage lm = (IMessage) lhs;
- IMessage rm = (IMessage) rhs;
+ IMessage lm = lhs;
+ IMessage rm = rhs;
ISourceLocation ls = (lm == null ? null : lm.getSourceLocation());
ISourceLocation rs = (rm == null ? null : rm.getSourceLocation());
int left = (ls == null ? -1 : ls.getLine());
@@ -94,8 +95,8 @@ public class Diffs {
return true;
}
};
- // // XXX List -> Collection b/c comparator orders
- // public static final Diffs NONE
+ // // XXX List -> Collection b/c comparator orders
+ // public static final Diffs NONE
// = new Diffs("NONE", Collections.EMPTY_LIST, Collections.EMPTY_LIST);
public static Diffs makeDiffs(
@@ -118,7 +119,7 @@ public class Diffs {
IMessage[] actual) {
return makeDiffs(label, expected, actual, null, null);
}
-
+
private static int getLine(ISourceLocation loc) {
int result = -1;
if (null != loc) {
@@ -148,11 +149,11 @@ public class Diffs {
IMessage[] actual,
IMessage.Kind[] ignoreExpectedKinds,
IMessage.Kind[] ignoreActualKinds) {
- List exp = getExcept(expected, ignoreExpectedKinds);
- List act = getExcept(actual, ignoreActualKinds);
+ List<IMessage> exp = getExcept(expected, ignoreExpectedKinds);
+ List<IMessage> act = getExcept(actual, ignoreActualKinds);
- ArrayList missing = new ArrayList();
- List unexpected = new ArrayList();
+ List<IMessage> missing = new ArrayList<>();
+ List<IMessage> unexpected = new ArrayList<>();
if (LangUtil.isEmpty(expected)) {
unexpected.addAll(act);
@@ -206,7 +207,7 @@ public class Diffs {
unexpected.add(actualMessage);
}
}
- // missing: all expected results not found
+ // missing: all expected results not found
exp.removeAll(expectedFound);
missing.addAll(exp);
}
@@ -266,7 +267,7 @@ public class Diffs {
// if (LangUtil.isEmpty(kinds)) {
// return sink.length;
// } else if (LangUtil.isEmpty(sink)) {
- // return 0;
+ // return 0;
// }
// int from = -1;
// int to = -1;
@@ -337,7 +338,7 @@ public class Diffs {
* extraSourceLocation[]
* if any are defined in expected, then there
* must be exactly the actual elements as are
- * defined in expected (so it is an error to
+ * defined in expected (so it is an error to
* not define all if you define any)
* <pre>
* @param expected
@@ -366,11 +367,11 @@ public class Diffs {
return false;
}
ISourceLocation[] esl =
- (ISourceLocation[]) expected.getExtraSourceLocations().toArray(
- new ISourceLocation[0]);
+ expected.getExtraSourceLocations().toArray(
+ new ISourceLocation[0]);
ISourceLocation[] asl =
- (ISourceLocation[]) actual.getExtraSourceLocations().toArray(
- new ISourceLocation[0]);
+ actual.getExtraSourceLocations().toArray(
+ new ISourceLocation[0]);
Arrays.sort(esl, SORT_SOURCELOC);
Arrays.sort(asl, SORT_SOURCELOC);
@@ -385,7 +386,7 @@ public class Diffs {
* (i.e., it ignored any extra source locations if no expectations stated).
* XXX need const like NO_FILE.
* @param expected the sorted ISourceLocation[] expected
- * @param expected the actual sorted ISourceLocation[]
+ * @param expected the actual sorted ISourceLocation[]
* @return true if any expected element is expected by the corresponding actual element.
*/
static boolean expectingSourceLocations(
@@ -442,10 +443,10 @@ public class Diffs {
}
}
- private static ArrayList getExcept(
+ private static List<IMessage> getExcept(
IMessage[] source,
IMessage.Kind[] skip) {
- ArrayList<IMessage> sink = new ArrayList<>();
+ List<IMessage> sink = new ArrayList<>();
if (LangUtil.isEmpty(source)) {
return sink;
}
@@ -482,10 +483,10 @@ public class Diffs {
public final String label;
/** immutable List */
- public final List missing;
+ public final List<TestResult> missing;
/** immutable List */
- public final List unexpected;
+ public final List<TestResult> unexpected;
/** true if there are any missing or unexpected */
public final boolean different;
@@ -505,11 +506,11 @@ public class Diffs {
((0 != this.missing.size()) || (0 != this.unexpected.size()));
}
- /**
+ /**
* Report missing and extra items to handler.
- * For each item in missing or unexpected, this creates a {kind} IMessage with
+ * For each item in missing or unexpected, this creates a {kind} IMessage with
* the text "{missing|unexpected} {label}: {message}"
- * where {message} is the result of
+ * where {message} is the result of
* <code>MessageUtil.renderMessage(IMessage)</code>.
* @param handler where the messages go - not null
* @param kind the kind of message to construct - not null
@@ -540,7 +541,7 @@ public class Diffs {
+ missing.size()
+ ")";
}
- public static interface Filter {
+ public interface Filter {
/** @return true to keep input in list of messages */
boolean accept(Object input);
}
diff --git a/testing/src/test/java/org/aspectj/testing/util/TestDiffs.java b/testing/src/test/java/org/aspectj/testing/util/TestDiffs.java
index ca1aa72ed..bdb66dc08 100644
--- a/testing/src/test/java/org/aspectj/testing/util/TestDiffs.java
+++ b/testing/src/test/java/org/aspectj/testing/util/TestDiffs.java
@@ -1,14 +1,14 @@
/* *******************************************************************
- * Copyright (c) 1999-2001 Xerox Corporation,
+ * Copyright (c) 1999-2001 Xerox Corporation,
* 2002 Palo Alto Research Center, Incorporated (PARC).
- * 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:
- * Xerox/PARC initial implementation
+ * 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:
+ * Xerox/PARC initial implementation
* ******************************************************************/
package org.aspectj.testing.util;
@@ -27,7 +27,7 @@ import java.util.ListIterator;
import org.aspectj.util.LangUtil;
/**
- * Calculated differences between two test runs
+ * Calculated differences between two test runs
* based on their output files
* assuming that tests are logged with prefix [PASS|FAIL]
* (as they are when using <tt>-traceTestsMin</tt> with the Harness).
@@ -51,7 +51,7 @@ public class TestDiffs { // XXX pretty dumb implementation
print(System.out, result.missing, "missing");
print(System.out, result.fixed, "fixed");
print(System.out, result.broken, "broken");
-
+
System.out.println("## Summary");
System.out.println(" # expected " + result.expected.size() + " tests: " + args[0] );
System.out.println(" # actual " + result.actual.size() + " tests: " + args[1]);
@@ -64,42 +64,42 @@ public class TestDiffs { // XXX pretty dumb implementation
append(sb, result.stillFailing, " still failing");
System.out.println(" # diffs: " + sb);
}
-
+
/**
* @param expected the expected/old File results with Harness -traceTestsMin lines
* @param actual the actual/new File results with Harness -traceTestsMin lines
* @return TestDiffs null if error, valid otherwise
*/
public static TestDiffs compareResults(File expected, File actual) {
- ArrayList exp = null;
- ArrayList act = null;
+ List<TestResult> exp = null;
+ List<TestResult> act = null;
File reading = expected;
try {
exp = TestDiffs.readTestResults(expected, expected.getPath());
reading = actual;
act = TestDiffs.readTestResults(actual, actual.getPath());
-
+
Diffs tests = Diffs.makeDiffs("tests", exp, act, TestResult.BY_NAME);
// remove missing/unexpected (removed, added) tests from results
// otherwise, unexpected-[pass|fail] look like [fixes|broken]
- List expResults = trimByName(exp, tests.missing);
- List actResults = trimByName(act, tests.unexpected);
-
+ List<TestResult> expResults = trimByName(exp, tests.missing);
+ List<TestResult> actResults = trimByName(act, tests.unexpected);
+
Diffs results = Diffs.makeDiffs("results", expResults, actResults, TestResult.BY_PASSNAME);
// broken tests show up in results as unexpected-fail or missing-pass
// fixed tests show up in results as unexpected-pass or missing-fail
- ArrayList broken = new ArrayList();
- ArrayList fixed = new ArrayList();
+ ArrayList<TestResult> broken = new ArrayList<TestResult>();
+ ArrayList<TestResult> fixed = new ArrayList<TestResult>();
split(results.unexpected, fixed, broken);
return new TestDiffs(
exp,
act,
- tests.missing,
- tests.unexpected,
- broken,
- fixed);
+ tests.missing,
+ tests.unexpected,
+ broken,
+ fixed);
} catch (IOException e) {
System.err.println("error reading " + reading);
e.printStackTrace(System.err); // XXX
@@ -107,7 +107,7 @@ public class TestDiffs { // XXX pretty dumb implementation
}
}
- private static void append(StringBuffer sb, List list, String label) {
+ private static void append(StringBuffer sb, List<TestResult> list, String label) {
if (!LangUtil.isEmpty(list)) {
if (0 < sb.length()) {
sb.append(" ");
@@ -115,8 +115,8 @@ public class TestDiffs { // XXX pretty dumb implementation
sb.append(list.size() + label);
}
}
-
- private static void print(PrintStream out, List list, String label) {
+
+ private static void print(PrintStream out, List<TestResult> list, String label) {
if ((null == out) || LangUtil.isEmpty(list)) {
return;
}
@@ -130,20 +130,20 @@ public class TestDiffs { // XXX pretty dumb implementation
}
out.println("## END " + LABEL);
}
-
+
/**
- * Create ArrayList with input TestResult list
+ * Create ArrayList with input TestResult list
* but without elements in trim list,
* comparing based on test name only.
* @param input
* @param trim
* @return ArrayList with all input except those in trim (by name)
*/
- private static ArrayList trimByName(List input, List trim) {
- ArrayList result = new ArrayList(input);
+ private static List<TestResult> trimByName(List<TestResult> input, List<TestResult> trim) {
+ List<TestResult> result = new ArrayList<TestResult>(input);
if (!LangUtil.isEmpty(input) && !LangUtil.isEmpty(trim)) {
- for (ListIterator iter = result.listIterator(); iter.hasNext();) {
- TestResult inputItem = (TestResult) iter.next();
+ for (ListIterator<TestResult> iter = result.listIterator(); iter.hasNext();) {
+ TestResult inputItem = iter.next();
for (Object o : trim) {
TestResult trimItem = (TestResult) o;
if (inputItem.test.equals(trimItem.test)) {
@@ -156,9 +156,9 @@ public class TestDiffs { // XXX pretty dumb implementation
return result;
}
-
+
/** split input List by whether the TestResult element passed or failed */
- private static void split(List input, List pass, List fail) {
+ private static void split(List<TestResult> input, List<TestResult> pass, List<TestResult> fail) {
for (Object o : input) {
TestResult result = (TestResult) o;
if (result.pass) {
@@ -169,18 +169,18 @@ public class TestDiffs { // XXX pretty dumb implementation
}
}
- /**
+ /**
* Read a file of test results,
* defined as lines starting with [PASS|FAIL]
* (produced by Harness option <tt>-traceTestsmin</tt>).
- * @return ArrayList of TestResult, one for every -traceTestsMin line in File
+ * @return ArrayList of TestResult, one for every -traceTestsMin line in File
*/
- private static ArrayList readTestResults(File file, String config) throws IOException {
+ private static ArrayList<TestResult> readTestResults(File file, String config) throws IOException {
LangUtil.throwIaxIfNull(file, "file");
if (null == config) {
config = file.getPath();
}
- ArrayList result = new ArrayList();
+ ArrayList<TestResult> result = new ArrayList<TestResult>();
FileReader in = null;
try {
in = new FileReader(file);
@@ -208,56 +208,56 @@ public class TestDiffs { // XXX pretty dumb implementation
}
return result;
}
-
- private static List safeList(List list) {
+
+ private static List<TestResult> safeList(List<TestResult> list) {
return (null == list
? Collections.EMPTY_LIST
: Collections.unmodifiableList(list));
}
-
+
/** List of TestResult results from expected run. */
- public final List expected;
+ public final List<TestResult> expected;
/** List of TestResult results from actual run. */
- public final List actual;
-
+ public final List<TestResult> actual;
+
/** List of TestResult tests disappeared from test suite between expected and actual runs. */
- public final List missing;
-
+ public final List<TestResult> missing;
+
/** List of TestResult tests added to test suite between expected and actual runs. */
- public final List added;
-
+ public final List<TestResult> added;
+
/** List of TestResult tests in both runs, expected to pass but actually failed */
- public final List broken;
-
+ public final List<TestResult> broken;
+
/** List of TestResult tests in both runs, expected to fail but actually passed */
- public final List fixed;
-
+ public final List<TestResult> fixed;
+
/** List of TestResult passed tests in expected run */
- public final List expectedPassed;
+ public final List<TestResult> expectedPassed;
/** List of TestResult failed tests in expected run */
- public final List expectedFailed;
+ public final List<TestResult> expectedFailed;
/** List of TestResult passed tests in actual run */
- public final List actualPassed;
+ public final List<TestResult> actualPassed;
/** List of TestResult tests failed in actual run */
- public final List actualFailed;
+ public final List<TestResult> actualFailed;
/** List of TestResult tests passed in both expected and actual run */
- public final List stillPassing;
+ public final List<TestResult> stillPassing;
/** List of TestResult tests failed in both expected and actual run */
- public final List stillFailing;
-
+ public final List<TestResult> stillFailing;
+
private TestDiffs(
- List expected,
- List actual,
- List missing,
- List added,
- List broken,
- List fixed) {
+ List<TestResult> expected,
+ List<TestResult> actual,
+ List<TestResult> missing,
+ List<TestResult> added,
+ List<TestResult> broken,
+ List<TestResult> fixed) {
this.expected = safeList(expected);
this.actual = safeList(actual);
this.missing = safeList(missing);
@@ -265,35 +265,35 @@ public class TestDiffs { // XXX pretty dumb implementation
this.broken = safeList(broken);
this.fixed = safeList(fixed);
// expected[Passed|Failed]
- ArrayList passed = new ArrayList();
- ArrayList failed = new ArrayList();
+ List<TestResult> passed = new ArrayList<TestResult>();
+ List<TestResult> failed = new ArrayList<TestResult>();
split(this.expected, passed, failed);
expectedPassed = safeList(passed);
expectedFailed = safeList(failed);
// actual[Passed|Failed]
- passed = new ArrayList();
- failed = new ArrayList();
+ passed = new ArrayList<TestResult>();
+ failed = new ArrayList<TestResult>();
split(this.actual, passed, failed);
actualPassed = safeList(passed);
actualFailed = safeList(failed);
// stillPassing: expected.passed w/o broken, missingPasses
- passed = new ArrayList(expectedPassed);
+ passed = new ArrayList<TestResult>(expectedPassed);
passed = trimByName(passed, this.broken);
- ArrayList missingPasses = new ArrayList();
- ArrayList missingFails = new ArrayList();
+ ArrayList<TestResult> missingPasses = new ArrayList<TestResult>();
+ ArrayList<TestResult> missingFails = new ArrayList<TestResult>();
split(this.missing, missingPasses, missingFails);
- passed = trimByName(passed, missingPasses);
+ passed = trimByName(passed, missingPasses);
stillPassing = safeList(passed);
// stillFailing: expected.failed w/o fixed, missingFails
- failed = new ArrayList(expectedFailed);
+ failed = new ArrayList<TestResult>(expectedFailed);
failed = trimByName(failed, this.fixed);
- failed = trimByName(failed, missingFails);
+ failed = trimByName(failed, missingFails);
stillFailing = safeList(failed);
}
-
+
/** results of a test */
public static class TestResult {
public static final Comparator BY_PASSNAME = new Comparator() {
@@ -303,16 +303,16 @@ public class TestDiffs { // XXX pretty dumb implementation
}
TestResult lhs = (TestResult) o1;
TestResult rhs = (TestResult) o2;
- return (lhs.pass == rhs.pass
+ return (lhs.pass == rhs.pass
? lhs.test.compareTo(rhs.test)
: (lhs.pass ? 1 : -1 ));
}
-
+
public boolean equals(Object lhs, Object rhs) {
return (0 == compare(lhs, rhs));
}
};
-
+
public static final Comparator BY_NAME = new Comparator() {
public int compare(Object o1, Object o2) {
if (o1 == o2) {
@@ -322,20 +322,20 @@ public class TestDiffs { // XXX pretty dumb implementation
TestResult rhs = (TestResult) o2;
return lhs.test.compareTo(rhs.test);
}
-
+
public boolean equals(Object lhs, Object rhs) {
return (0 == compare(lhs, rhs));
}
};
-
+
//private static final ArrayList TESTS = new ArrayList();
public static final String FIELDSEP = "\t";
-
+
public final String test;
public final String config;
public final boolean pass;
private final String toString;
-
+
public TestResult(String test, String config, boolean pass) {
LangUtil.throwIaxIfNull(test, "test");
LangUtil.throwIaxIfNull(test, "config");
@@ -345,7 +345,7 @@ public class TestDiffs { // XXX pretty dumb implementation
toString = (pass ? "PASS" : "FAIL") + FIELDSEP + test + FIELDSEP + config;
}
-
+
/** @return [PASS|FAIL]{FIELDSEP}test{FIELDSEP}config */
public String toString() {
return toString;