| /*========================================================================= |
| * Copyright (c) 2010-2014 Pivotal Software, Inc. All Rights Reserved. |
| * This product is protected by U.S. and international copyright |
| * and intellectual property laws. Pivotal products are covered by |
| * one or more patents listed at http://www.pivotal.io/patents. |
| *========================================================================= |
| */ |
| package com.gemstone.gemfire; |
| |
| import com.sun.javadoc.*; |
| import java.io.*; |
| import java.text.BreakIterator; |
| import java.util.*; |
| import junit.framework.TestCase; |
| import perffmwk.Formatter; |
| |
| /** |
| * This class is a Javadoc <A |
| * href="http://java.sun.com/j2se/1.4.2/docs/tooldocs/javadoc/overview.html">doclet</A> |
| * that generates a text file that summarizes unit test classes and |
| * methods. |
| * |
| * @see com.sun.javadoc.Doclet |
| * |
| * @author David Whitlock |
| * |
| * @since 3.0 |
| */ |
| public class UnitTestDoclet { |
| |
| /** |
| * Returns the number of arguments for the given command option |
| * (include the option itself) |
| */ |
| public static int optionLength(String option) { |
| if (option.equals("-output")) { |
| return 2; |
| |
| } else { |
| // Unknown option |
| return 0; |
| } |
| } |
| |
| public static boolean validOptions(String[][] options, |
| DocErrorReporter reporter) { |
| boolean sawOutput = false; |
| |
| for (int i = 0; i < options.length; i++) { |
| String[] option = options[i]; |
| |
| if (option[0].equals("-output")) { |
| File output = new File(option[1]); |
| if (output.exists() && output.isDirectory()) { |
| reporter.printError("Output file " + output + |
| " is a directory"); |
| return false; |
| |
| } else { |
| sawOutput = true; |
| } |
| } |
| } |
| |
| if (!sawOutput) { |
| reporter.printError("Missing -output"); |
| return false; |
| } |
| |
| return true; |
| } |
| |
| /** |
| * The entry point for the doclet |
| */ |
| public static boolean start(RootDoc root) { |
| String[][] options = root.options(); |
| |
| File outputFile = null; |
| for (int i = 0; i < options.length; i++) { |
| String[] option = options[i]; |
| if (option[0].equals("-output")) { |
| outputFile = new File(option[1]); |
| } |
| } |
| |
| if (outputFile == null) { |
| root.printError("Internal Error: No output file"); |
| return false; |
| |
| } else { |
| root.printNotice("Generating " + outputFile); |
| } |
| |
| try { |
| PrintWriter pw = |
| new PrintWriter(new FileWriter(outputFile)); |
| Formatter.center("GemFire Unit Test Summary", pw); |
| Formatter.center(new Date().toString(), pw); |
| pw.println(""); |
| |
| ClassDoc[] classes = root.classes(); |
| Arrays.sort(classes, new Comparator() { |
| public int compare(Object o1, Object o2) { |
| ClassDoc c1 = (ClassDoc) o1; |
| ClassDoc c2 = (ClassDoc) o2; |
| return c1.qualifiedName().compareTo(c2.qualifiedName()); |
| } |
| }); |
| for (int i = 0; i < classes.length; i++) { |
| ClassDoc c = classes[i]; |
| if (!c.isAbstract() && isUnitTest(c)) { |
| document(c, pw); |
| } |
| } |
| |
| pw.flush(); |
| pw.close(); |
| |
| } catch (IOException ex) { |
| StringWriter sw = new StringWriter(); |
| ex.printStackTrace(new PrintWriter(sw, true)); |
| root.printError(sw.toString()); |
| return false; |
| } |
| |
| return true; |
| } |
| |
| /** |
| * Returns whether or not a class is a unit test. That is, whether |
| * or not it is a subclass of {@link junit.framework.TestCase}. |
| */ |
| private static boolean isUnitTest(ClassDoc c) { |
| if (c == null) { |
| return false; |
| |
| } else if (c.qualifiedName().equals(TestCase.class.getName())) { |
| return true; |
| |
| } else { |
| return isUnitTest(c.superclass()); |
| } |
| } |
| |
| /** |
| * Summarizes the test methods of the given class |
| */ |
| public static void document(ClassDoc c, PrintWriter pw) |
| throws IOException { |
| |
| pw.println(c.qualifiedName()); |
| |
| { |
| String comment = c.commentText(); |
| if (comment != null && !comment.equals("")) { |
| pw.println(""); |
| indent(comment, 4, pw); |
| pw.println(""); |
| } |
| } |
| |
| MethodDoc[] methods = getTestMethods(c); |
| for (int i = 0; i < methods.length; i++) { |
| MethodDoc method = methods[i]; |
| pw.print(" "); |
| pw.println(method.name()); |
| |
| String comment = method.commentText(); |
| if (comment != null && !comment.equals("")) { |
| pw.println(""); |
| indent(comment, 6, pw); |
| pw.println(""); |
| } |
| } |
| |
| pw.println(""); |
| } |
| |
| /** |
| * Returns an array containing all of the "test" methods (including |
| * those that are inherited) for the given class. |
| */ |
| private static MethodDoc[] getTestMethods(ClassDoc c) { |
| Set set = new TreeSet(); |
| while (c != null) { |
| MethodDoc[] methods = c.methods(); |
| for (int i = 0; i < methods.length; i++) { |
| MethodDoc method = methods[i]; |
| if (method.isPublic() && method.parameters().length == 0 && |
| method.name().startsWith("test")) { |
| set.add(method); |
| } |
| } |
| |
| c = c.superclass(); |
| } |
| |
| return (MethodDoc[]) set.toArray(new MethodDoc[0]); |
| } |
| |
| /** |
| * Indents a block of text a given amount. |
| */ |
| private static void indent(String text, final int indent, |
| PrintWriter pw) { |
| StringBuffer sb = new StringBuffer(); |
| for (int i = 0; i < indent; i++) { |
| sb.append(" "); |
| } |
| String spaces = sb.toString(); |
| |
| pw.print(spaces); |
| |
| int printed = indent; |
| boolean firstWord = true; |
| |
| BreakIterator boundary = BreakIterator.getWordInstance(); |
| boundary.setText(text); |
| int start = boundary.first(); |
| for (int end = boundary.next(); end != BreakIterator.DONE; |
| start = end, end = boundary.next()) { |
| |
| String word = text.substring(start, end); |
| |
| if (printed + word.length() > 72) { |
| pw.println(""); |
| pw.print(spaces); |
| printed = indent; |
| firstWord = true; |
| } |
| |
| if (word.charAt(word.length() - 1) == '\n') { |
| pw.write(word, 0, word.length() - 1); |
| |
| } else if (firstWord && |
| Character.isWhitespace(word.charAt(0))) { |
| pw.write(word, 1, word.length() - 1); |
| |
| } else { |
| pw.print(word); |
| } |
| printed += (end - start); |
| firstWord = false; |
| } |
| |
| pw.println(""); |
| } |
| |
| } |