maven-surefire-commits mailing list archives

Site index · List index
Message view « Date » · « Thread »
Top « Date » · « Thread »
From krosenv...@apache.org
Subject svn commit: r1101164 - /maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java
Date Mon, 09 May 2011 19:31:33 GMT
Author: krosenvold
Date: Mon May  9 19:31:33 2011
New Revision: 1101164

URL: http://svn.apache.org/viewvc?rev=1101164&view=rev
Log:
o Javadoc on wire level protocol and thread safety notes

Modified:
    maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java

Modified: maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java
URL: http://svn.apache.org/viewvc/maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java?rev=1101164&r1=1101163&r2=1101164&view=diff
==============================================================================
--- maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java
(original)
+++ maven/surefire/trunk/surefire-api/src/main/java/org/apache/maven/surefire/booter/ForkingRunListener.java
Mon May  9 19:31:33 2011
@@ -31,7 +31,19 @@ import org.apache.maven.surefire.util.in
 import org.apache.maven.surefire.util.internal.StringUtils;
 
 /**
- * Encodes the full output of the test run to the stdout stream
+ * Encodes the full output of the test run to the stdout stream.
+ * <p/>
+ * This class and the ForkClient contain the full definition of the
+ * "wire-level" protocol used by the forked process. The protocol
+ * is *not* part of any public api and may change without further
+ * notice.
+ * <p/>
+ * This class is threadsafe.
+ * <p/>
+ * The synchronization in the underlying PrintStream (target instance)
+ * is used to preserve thread safety of the ouput stream. To perform
+ * multiple writes/prints for a single request, they must
+ * synchronize on "target" variable in this class.
  *
  * @author Kristian Rosenvold
  */
@@ -129,7 +141,7 @@ public class ForkingRunListener
         target.print( toString( BOOTERCODE_TEST_SKIPPED, report, testSetChannelId ) );
     }
 
-    synchronized void sendProps()
+    void sendProps()
     {
         Properties systemProperties = System.getProperties();
 
@@ -147,7 +159,7 @@ public class ForkingRunListener
                 {
                     value = "null";
                 }
-                target.print( toPropertyString( key, value ));
+                target.print( toPropertyString( key, value ) );
             }
         }
     }
@@ -160,7 +172,7 @@ public class ForkingRunListener
         int i = StringUtils.escapeJavaStyleString( content, 0, buf, off, len );
         content[i++] = (byte) '\n';
 
-        synchronized ( target ) // Questionable synchronization
+        synchronized ( target ) // See notes about synhronization/thread safety in class
javadoc
         {
             target.write( header, 0, header.length );
             target.write( content, 0, i );



Mime
View raw message