Coverage Report - org.apache.maven.plugin.surefire.booterclient.output.ForkClient
 
Classes in this File Line Coverage Branch Coverage Complexity
ForkClient
0%
0/89
0%
0/46
4.1
 
 1  
 package org.apache.maven.plugin.surefire.booterclient.output;
 2  
 
 3  
 /*
 4  
  * Licensed to the Apache Software Foundation (ASF) under one
 5  
  * or more contributor license agreements.  See the NOTICE file
 6  
  * distributed with this work for additional information
 7  
  * regarding copyright ownership.  The ASF licenses this file
 8  
  * to you under the Apache License, Version 2.0 (the
 9  
  * "License"); you may not use this file except in compliance
 10  
  * with the License.  You may obtain a copy of the License at
 11  
  *
 12  
  *     http://www.apache.org/licenses/LICENSE-2.0
 13  
  *
 14  
  * Unless required by applicable law or agreed to in writing,
 15  
  * software distributed under the License is distributed on an
 16  
  * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
 17  
  * KIND, either express or implied.  See the License for the
 18  
  * specific language governing permissions and limitations
 19  
  * under the License.
 20  
  */
 21  
 
 22  
 import java.io.BufferedReader;
 23  
 import java.io.IOException;
 24  
 import java.io.StringReader;
 25  
 import java.io.StringWriter;
 26  
 import java.util.Collections;
 27  
 import java.util.HashMap;
 28  
 import java.util.Map;
 29  
 import java.util.Properties;
 30  
 import java.util.StringTokenizer;
 31  
 import org.apache.maven.surefire.booter.ForkingRunListener;
 32  
 import org.apache.maven.surefire.report.CategorizedReportEntry;
 33  
 import org.apache.maven.surefire.report.ConsoleOutputReceiver;
 34  
 import org.apache.maven.surefire.report.ConsoleLogger;
 35  
 import org.apache.maven.surefire.report.ReportEntry;
 36  
 import org.apache.maven.surefire.report.ReporterException;
 37  
 import org.apache.maven.surefire.report.ReporterFactory;
 38  
 import org.apache.maven.surefire.report.RunListener;
 39  
 import org.apache.maven.surefire.report.SimpleReportEntry;
 40  
 import org.apache.maven.surefire.report.StackTraceWriter;
 41  
 import org.apache.maven.surefire.util.NestedRuntimeException;
 42  
 import org.apache.maven.surefire.util.internal.StringUtils;
 43  
 import org.codehaus.plexus.util.cli.StreamConsumer;
 44  
 
 45  
 /**
 46  
  * Knows how to reconstruct *all* the state transmitted over stdout by the forked process.
 47  
  *
 48  
  * @author Kristian Rosenvold
 49  
  */
 50  
 public class ForkClient
 51  
     implements StreamConsumer
 52  
 {
 53  
     private final ReporterFactory providerReporterFactory;
 54  
 
 55  0
     private final Map testSetReporters = Collections.synchronizedMap( new HashMap() );
 56  
 
 57  
     private final Properties testVmSystemProperties;
 58  
 
 59  
     public ForkClient( ReporterFactory providerReporterFactory, Properties testVmSystemProperties )
 60  0
     {
 61  0
         this.providerReporterFactory = providerReporterFactory;
 62  0
         this.testVmSystemProperties = testVmSystemProperties;
 63  0
     }
 64  
 
 65  
     public void consumeLine( String s )
 66  
     {
 67  
         try
 68  
         {
 69  0
             if ( s.length() == 0 )
 70  
             {
 71  0
                 return;
 72  
             }
 73  0
             final byte operationId = (byte) s.charAt( 0 );
 74  0
             int commma = s.indexOf( ",", 3 );
 75  0
             if ( commma < 0 )
 76  
             {
 77  0
                 System.out.println( s );
 78  0
                 return;
 79  
             }
 80  0
             final Integer channelNumber = new Integer( Integer.parseInt( s.substring( 2, commma ), 16 ) );
 81  0
             RunListener reporter = (RunListener) testSetReporters.get( channelNumber );
 82  0
             if ( reporter == null )
 83  
             {
 84  0
                 reporter = providerReporterFactory.createReporter();
 85  
                 //reporter = new AsynchRunListener( reporter, "ForkClient" );
 86  0
                 testSetReporters.put( channelNumber, reporter );
 87  
             }
 88  0
             int rest = s.indexOf( ",", commma );
 89  0
             final String remaining = s.substring( rest + 1 );
 90  
 
 91  0
             switch ( operationId )
 92  
             {
 93  
                 case ForkingRunListener.BOOTERCODE_TESTSET_STARTING:
 94  0
                     reporter.testSetStarting( createReportEntry( remaining ) );
 95  0
                     break;
 96  
                 case ForkingRunListener.BOOTERCODE_TESTSET_COMPLETED:
 97  0
                     reporter.testSetCompleted( createReportEntry( remaining ) );
 98  0
                     break;
 99  
                 case ForkingRunListener.BOOTERCODE_TEST_STARTING:
 100  0
                     reporter.testStarting( createReportEntry( remaining) );
 101  0
                     break;
 102  
                 case ForkingRunListener.BOOTERCODE_TEST_SUCCEEDED:
 103  0
                     reporter.testSucceeded( createReportEntry( remaining ) );
 104  0
                     break;
 105  
                 case ForkingRunListener.BOOTERCODE_TEST_FAILED:
 106  0
                     reporter.testFailed( createReportEntry( remaining ) );
 107  0
                     break;
 108  
                 case ForkingRunListener.BOOTERCODE_TEST_SKIPPED:
 109  0
                     reporter.testSkipped( createReportEntry( remaining ) );
 110  0
                     break;
 111  
                 case ForkingRunListener.BOOTERCODE_TEST_ERROR:
 112  0
                     reporter.testError( createReportEntry( remaining ) );
 113  0
                     break;
 114  
                 case ForkingRunListener.BOOTERCODE_TEST_ASSUMPTIONFAILURE:
 115  0
                     reporter.testAssumptionFailure( createReportEntry( remaining ) );
 116  0
                     break;
 117  
                 case ForkingRunListener.BOOTERCODE_SYSPROPS:
 118  0
                     int keyEnd = remaining.indexOf( "," );
 119  0
                     StringWriter key = new StringWriter();
 120  0
                     StringWriter value = new StringWriter();
 121  0
                     StringUtils.unescapeJava( key, remaining.substring( 0, keyEnd ) );
 122  0
                     StringUtils.unescapeJava( value, remaining.substring( keyEnd + 1 ) );
 123  
 
 124  0
                     synchronized ( testVmSystemProperties )
 125  
                     {
 126  0
                         testVmSystemProperties.put( key, value );
 127  0
                     }
 128  0
                     break;
 129  
                 case ForkingRunListener.BOOTERCODE_STDOUT:
 130  0
                     byte[] bytes = new byte[remaining.length() * 2];
 131  0
                     int len = StringUtils.unescapeJava( bytes, remaining );
 132  0
                     ( (ConsoleOutputReceiver) reporter ).writeTestOutput( bytes, 0, len, true );
 133  0
                     break;
 134  
                 case ForkingRunListener.BOOTERCODE_STDERR:
 135  0
                     bytes = new byte[remaining.length() * 2];
 136  0
                     len = StringUtils.unescapeJava( bytes, remaining );
 137  0
                     ( (ConsoleOutputReceiver) reporter ).writeTestOutput( bytes, 0, len, false );
 138  0
                     break;
 139  
                 case ForkingRunListener.BOOTERCODE_CONSOLE:
 140  0
                     ( (ConsoleLogger) reporter ).info( createConsoleMessage( remaining ) );
 141  0
                     break;
 142  
                 default:
 143  0
                     System.out.println( s );
 144  
             }
 145  
         }
 146  0
         catch ( NumberFormatException e )
 147  
         {
 148  0
             System.out.println( s );
 149  
         }
 150  0
         catch ( ReporterException e )
 151  
         {
 152  0
             throw new NestedRuntimeException( e );
 153  0
         }
 154  0
     }
 155  
 
 156  
     public void consumeMultiLineContent( String s )
 157  
         throws IOException
 158  
     {
 159  0
         BufferedReader stringReader = new BufferedReader( new StringReader( s ) );
 160  
         String s1;
 161  0
         while ( ( s1 = stringReader.readLine() ) != null )
 162  
         {
 163  0
             consumeLine( s1 );
 164  
         }
 165  0
     }
 166  
 
 167  
     private String createConsoleMessage( String remaining )
 168  
     {
 169  0
         return unescape( remaining );
 170  
     }
 171  
 
 172  
     private ReportEntry createReportEntry( String untokenized)
 173  
     {
 174  0
         StringTokenizer tokens = new StringTokenizer(untokenized, ",");
 175  
         try
 176  
         {
 177  0
             String source = tokens.nextToken();
 178  0
             String name = tokens.nextToken();
 179  0
             String group = nullableCsv( tokens.nextToken() );
 180  0
             String elapsedStr = tokens.nextToken();
 181  0
             Integer elapsed = "null".equals( elapsedStr ) ? null : Integer.decode( elapsedStr );
 182  0
             final StackTraceWriter stackTraceWriter =
 183  
                 tokens.hasMoreTokens() ? deserializeStackStraceWriter( tokens ) : null;
 184  
 
 185  0
             return group != null
 186  
                 ? new CategorizedReportEntry( source, name, group, stackTraceWriter, elapsed )
 187  
                 : new SimpleReportEntry( source, name, stackTraceWriter, elapsed );
 188  
         }
 189  0
         catch ( RuntimeException e )
 190  
         {
 191  0
             throw new RuntimeException( untokenized, e );
 192  
         }
 193  
     }
 194  
 
 195  
     private StackTraceWriter deserializeStackStraceWriter( StringTokenizer tokens )
 196  
     {
 197  
         StackTraceWriter stackTraceWriter;
 198  0
         String stackTraceMessage = nullableCsv( tokens.nextToken() );
 199  0
         String stackTrace = tokens.hasMoreTokens() ? nullableCsv( tokens.nextToken() ) : null;
 200  0
         stackTraceWriter =
 201  
             stackTrace != null ? new DeserializedStacktraceWriter( stackTraceMessage, stackTrace ) : null;
 202  0
         return stackTraceWriter;
 203  
     }
 204  
 
 205  
     private String nullableCsv( String source )
 206  
     {
 207  0
         if ( "null".equals( source ) )
 208  
         {
 209  0
             return null;
 210  
         }
 211  0
         return unescape( source );
 212  
     }
 213  
 
 214  
     private String unescape( String source )
 215  
     {
 216  0
         StringWriter stringWriter = new StringWriter( source.length() );
 217  
 
 218  0
         StringUtils.unescapeJava( stringWriter, source );
 219  0
         return stringWriter.getBuffer().toString();
 220  
     }
 221  
 
 222  
     /**
 223  
      * Used when getting reporters on the plugin side of a fork.
 224  
      *
 225  
      * @param channelNumber The logical channel number
 226  
      * @return A mock provider reporter
 227  
      */
 228  
     public RunListener getReporter( Integer channelNumber )
 229  
     {
 230  0
         return (RunListener) testSetReporters.get( channelNumber );
 231  
     }
 232  
 
 233  
 
 234  
     public void close()
 235  
     {
 236  
         /*Iterator iter = testSetReporters.values().iterator();
 237  
         while( iter.hasNext() )
 238  
         {
 239  
             ((AsynchRunListener)iter.next()).close();
 240  
         } */
 241  0
     }
 242  
 }