• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2013, Mike Samuel
2 // All rights reserved.
3 //
4 // Redistribution and use in source and binary forms, with or without
5 // modification, are permitted provided that the following conditions
6 // are met:
7 //
8 // Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // Neither the name of the OWASP nor the names of its contributors may
14 // be used to endorse or promote products derived from this software
15 // without specific prior written permission.
16 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
17 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
18 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
19 // FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
20 // COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
21 // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
22 // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
24 // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
26 // ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
27 // POSSIBILITY OF SUCH DAMAGE.
28 
29 package org.owasp.html;
30 
31 import java.io.PrintStream;
32 
33 import junit.framework.Test;
34 import junit.framework.TestResult;
35 import junit.textui.ResultPrinter;
36 import junit.textui.TestRunner;
37 
38 /**
39  * A test runner that dumps the names of tests as they start and finish to
40  * make debugging hanging tests easier.
41  */
42 public class VerboseTestRunner extends TestRunner {
43   final PrintStream out;
44 
VerboseTestRunner()45   public VerboseTestRunner() {
46     out = System.out;
47     setPrinter(new VerboseResultPrinter(out));
48   }
49 
50   private final class VerboseResultPrinter extends ResultPrinter {
51 
VerboseResultPrinter(PrintStream out)52     VerboseResultPrinter(PrintStream out) {
53       super(out);
54     }
55 
56     @Override
startTest(Test test)57     public void startTest(Test test) {
58       out.println("Started " + test);
59       out.flush();
60       super.startTest(test);
61     }
62 
63     @Override
endTest(Test test)64     public void endTest(Test test) {
65       super.endTest(test);
66       out.println("ended " + test);
67       out.flush();
68     }
69   }
70 
main(String[] argv)71   public static void main(String[] argv) {
72     VerboseTestRunner runner = new VerboseTestRunner();
73     try {
74       TestResult result = runner.start(argv);
75       if (!result.wasSuccessful()) {
76         System.exit(FAILURE_EXIT);
77       }
78       System.exit(SUCCESS_EXIT);
79     } catch (Exception ex) {
80       ex.printStackTrace();
81       System.exit(EXCEPTION_EXIT);
82     }
83   }
84 }
85