[ 
https://issues.apache.org/jira/browse/EXEC-122?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
 ]

Marcono1234 closed EXEC-122.
----------------------------
    Fix Version/s: 1.4.1
       Resolution: Fixed

Documentation has been adjusted to mention thread-safety requirements.

> PumpStreamHandler(OutputStream) constructor relies on stream being thread-safe
> ------------------------------------------------------------------------------
>
>                 Key: EXEC-122
>                 URL: https://issues.apache.org/jira/browse/EXEC-122
>             Project: Commons Exec
>          Issue Type: Bug
>    Affects Versions: 1.4.0
>            Reporter: Marcono1234
>            Priority: Minor
>             Fix For: 1.4.1
>
>
> h3. Description
> The constructor 
> {{org.apache.commons.exec.PumpStreamHandler.PumpStreamHandler(OutputStream)}} 
> which uses the {{OutputStream}} for both 'out' and 'err' currently does not 
> perform any synchronization, so potentially two threads are writing at the 
> same time to {{OutputStream}}.
> (This also applies to the other {{PumpStreamHandler}} constructor overloads 
> in case the user manually provides the same {{OutputStream}} instance both as 
> 'out' and 'err').
> This is error-prone because not all {{OutputStream}} implementations are 
> thread-safe, and the user might not be aware of this behavior.
> So it would be good to either:
> - Mention in the {{PumpStreamHandler(OutputStream)}} documentation (and 
> possibly for the other constructor overloads as well, if the same stream 
> instance is used), that the {{OutputStream}} has to be thread-safe
> - Or, {{PumpStreamHandler}} (or {{StreamPumper}}) should perform 
> synchronization, for example if the same stream instance is used by wrapping 
> it in a custom synchronizing {{OutputStream}}
> (though maybe that is not desired if the stream is already thread-safe, e.g. 
> {{Files.newOutputStream}})
> h3. Example
> Run this code snippet:
> {code}
> OutputStream out = new OutputStream() {
>     @Override
>     public void write(int b) throws IOException {
>         System.out.println(Thread.currentThread().getName());
>     }
> };
> PumpStreamHandler p = new PumpStreamHandler(out);
> p.setProcessOutputStream(new ByteArrayInputStream(new byte[1]));
> p.setProcessErrorStream(new ByteArrayInputStream(new byte[1]));
> p.start();
> Thread.sleep(1000);
> {code}
> You will see that it prints two different thread names. If you place a 
> breakpoint at the {{println}} you will also see that no synchronization is 
> performed, and the calls happen concurrently.



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to