Home | History | Annotate | Download | only in html
      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 
     45   public VerboseTestRunner() {
     46     out = System.out;
     47     setPrinter(new VerboseResultPrinter(out));
     48   }
     49 
     50   private final class VerboseResultPrinter extends ResultPrinter {
     51 
     52     VerboseResultPrinter(PrintStream out) {
     53       super(out);
     54     }
     55 
     56     @Override
     57     public void startTest(Test test) {
     58       out.println("Started " + test);
     59       out.flush();
     60       super.startTest(test);
     61     }
     62 
     63     @Override
     64     public void endTest(Test test) {
     65       super.endTest(test);
     66       out.println("ended " + test);
     67       out.flush();
     68     }
     69   }
     70 
     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