<html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"></head><body dir="auto"><div>I am really confused now. Why shouldn't Java EE concurrency not be able to define a standard way to configure custom executors? You can do that today, just in vendor specific ways...</div><div><br>On Mar 7, 2016, at 5:10 AM, Romain Manni-Bucau &lt;<a href="mailto:rmannibucau@gmail.com">rmannibucau@gmail.com</a>&gt; wrote:<br><br></div><blockquote type="cite"><div><div dir="ltr"><div class="gmail_extra"><div><div class="gmail_signature"><div dir="ltr"><div dir="ltr"><div dir="ltr"><div dir="ltr"><br></div></div></div></div></div></div><div class="gmail_quote">2016-03-07 10:57 GMT+01:00 Martin Kouba <span dir="ltr">&lt;<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a>&gt;</span>:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Dne 7.3.2016 v 09:45 Romain Manni-Bucau napsal(a):<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
2016-03-07 9:07 GMT+01:00 Martin Kouba &lt;<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a><br></span>
&lt;mailto:<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a>&gt;&gt;:<span class=""><br>
<br>
<br>
&nbsp; &nbsp; Dne 7.3.2016 v 09:03 Romain Manni-Bucau napsal(a):<br>
<br>
<br>
&nbsp; &nbsp; &nbsp; &nbsp; Le 7 mars 2016 08:35, "Martin Kouba" &lt;<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a><br>
&nbsp; &nbsp; &nbsp; &nbsp; &lt;mailto:<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a>&gt;<br></span>
&nbsp; &nbsp; &nbsp; &nbsp; &lt;mailto:<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a> &lt;mailto:<a href="mailto:mkouba@redhat.com" target="_blank">mkouba@redhat.com</a>&gt;&gt;&gt; a écrit :<div><div class="h5"><br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; Dne 6.3.2016 v 15:39 Romain Manni-Bucau napsal(a):<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; Hi guys,<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; as a user having a ComlpetionStage makes me loose some JDK<br>
&nbsp; &nbsp; &nbsp; &nbsp; utilities,<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; can we move back to CompletionFuture?<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; It would allow for instance:<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; // doesn't work with CompletionStage<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; CompletionFuture.allOf(event1.fireAsync(...),<br>
&nbsp; &nbsp; &nbsp; &nbsp; event2.fireAsync(...))<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;&nbsp; &nbsp; &nbsp; &nbsp; .then(...)<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; Well, this should work if the underlying CompletionStage impl<br>
&nbsp; &nbsp; &nbsp; &nbsp; supports toCompletableFuture(), i.e. in Weld 3:<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
<br>
&nbsp; &nbsp; &nbsp; &nbsp; Yes but it is not natural to convert it IMO = we can do better<br>
<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; CompletableFuture.allOf(event1.fireAsync(...).toCompletableFuture(),<br>
&nbsp; &nbsp; &nbsp; &nbsp; event2.fireAsync(...).toCompletableFuture())<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; AFAIK the default async execution facility of<br>
&nbsp; &nbsp; &nbsp; &nbsp; CompletableFuture is<br>
&nbsp; &nbsp; &nbsp; &nbsp; ForkJoinPool.commonPool() which is not a good fit for Java EE.<br>
&nbsp; &nbsp; &nbsp; &nbsp; Using the<br>
&nbsp; &nbsp; &nbsp; &nbsp; CompletionStage interface allows us to wrap the async calls<br>
&nbsp; &nbsp; &nbsp; &nbsp; without the<br>
&nbsp; &nbsp; &nbsp; &nbsp; specified executor (e.g.<br>
&nbsp; &nbsp; &nbsp; &nbsp; CompletionStage.thenApplyAsync(Function&lt;? super<br>
&nbsp; &nbsp; &nbsp; &nbsp; T, ? extends U&gt;)) and supply a default one provided by the impl.<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
<br>
&nbsp; &nbsp; &nbsp; &nbsp; Should use the pool in which the evznt is fired then "then step" is<br>
&nbsp; &nbsp; &nbsp; &nbsp; synchronous is my sample so all is decided at fire time<br>
<br>
<br>
&nbsp; &nbsp; I don't talk about your particular example - I understand that it's<br>
&nbsp; &nbsp; not using async exec (although the "then()" method does not exist).<br>
<br>
<br>
was supposed to represent the different flavours (thenRun, thenCompose,<br>
...) ;).<br>
<br>
That said I agree on the state switching the pool is better but with<br>
these 2 notes:<br>
<br>
- could be better to hide these poorly designed methods then -&gt; don't<br>
use CompletionXXX but a CDI API with a bridge to CompletionX to let the<br>
user go back on SE tools<br>
</div></div></blockquote>
<br>
Yep, this is one of the possible solutions. On the other hand, I don't think it's poorly designed. CompletionStage defines the "default asynchronous execution facility" and CDI spec states that the CompletionStage returned by fireAsync methods is container-specific. The impl may choose to clarify this "default asynchronous execution facility", i.e. there's place for innovation...<span class=""><br>
<br>
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
- we still don't have a *standard* config for the pool(s) underlying CDI<br>
features so it sounds as poor as SE solution IMO (at least a<br>
core/max/ttl config in beans.xml)<br>
</blockquote>
<br></span>
I don't think this should be standardized...<br>
<br></blockquote><div><br></div><div>Why? Typically if you take @Asynchronous (EJB spec) you have already this issue and this is often avoided when portability matters for that particular reason you don't know how you will behave. Or do you think concurrency-utilities solves it?</div><div>&nbsp;</div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span class="">
<br>
<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; Romain Manni-Bucau<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; @rmannibucau &lt;<a href="https://twitter.com/rmannibucau" rel="noreferrer" target="_blank">https://twitter.com/rmannibucau</a>&gt; | Blog<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; &lt;<a href="http://rmannibucau.wordpress.com" rel="noreferrer" target="_blank">http://rmannibucau.wordpress.com</a>&gt; | Github<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; &lt;<a href="https://github.com/rmannibucau" rel="noreferrer" target="_blank">https://github.com/rmannibucau</a>&gt; | LinkedIn<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; &lt;<a href="https://www.linkedin.com/in/rmannibucau" rel="noreferrer" target="_blank">https://www.linkedin.com/in/rmannibucau</a>&gt; | Tomitriber<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; &lt;<a href="http://www.tomitribe.com" rel="noreferrer" target="_blank">http://www.tomitribe.com</a>&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; _______________________________________________<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; cdi-dev mailing list<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; <a href="mailto:cdi-dev@lists.jboss.org" target="_blank">cdi-dev@lists.jboss.org</a> &lt;mailto:<a href="mailto:cdi-dev@lists.jboss.org" target="_blank">cdi-dev@lists.jboss.org</a>&gt;<br></span>
&nbsp; &nbsp; &nbsp; &nbsp; &lt;mailto:<a href="mailto:cdi-dev@lists.jboss.org" target="_blank">cdi-dev@lists.jboss.org</a> &lt;mailto:<a href="mailto:cdi-dev@lists.jboss.org" target="_blank">cdi-dev@lists.jboss.org</a>&gt;&gt;<span class=""><br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/cdi-dev" rel="noreferrer" target="_blank">https://lists.jboss.org/mailman/listinfo/cdi-dev</a><br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt; Note that for all code provided on this list, the provider<br>
&nbsp; &nbsp; &nbsp; &nbsp; licenses<br>
&nbsp; &nbsp; &nbsp; &nbsp; the code under the Apache License, Version 2<br>
&nbsp; &nbsp; &nbsp; &nbsp; (<a href="http://www.apache.org/licenses/LICENSE-2.0.html" rel="noreferrer" target="_blank">http://www.apache.org/licenses/LICENSE-2.0.html</a>). For all other<br>
&nbsp; &nbsp; &nbsp; &nbsp; ideas<br>
&nbsp; &nbsp; &nbsp; &nbsp; provided on this list, the provider waives all patent and other<br>
&nbsp; &nbsp; &nbsp; &nbsp; intellectual property rights inherent in such information.<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;&gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt;<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; --<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; Martin Kouba<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; Software Engineer<br>
&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &gt; Red Hat, Czech Republic<br>
<br>
<br>
&nbsp; &nbsp; --<br>
&nbsp; &nbsp; Martin Kouba<br>
&nbsp; &nbsp; Software Engineer<br>
&nbsp; &nbsp; Red Hat, Czech Republic<br>
<br>
<br>
</span></blockquote><div class="HOEnZb"><div class="h5">
<br>
-- <br>
Martin Kouba<br>
Software Engineer<br>
Red Hat, Czech Republic<br>
</div></div></blockquote></div><br></div></div>
</div></blockquote><blockquote type="cite"><div><span>_______________________________________________</span><br><span>cdi-dev mailing list</span><br><span><a href="mailto:cdi-dev@lists.jboss.org">cdi-dev@lists.jboss.org</a></span><br><span><a href="https://lists.jboss.org/mailman/listinfo/cdi-dev">https://lists.jboss.org/mailman/listinfo/cdi-dev</a></span><br><span></span><br><span>Note that for all code provided on this list, the provider licenses the code under the Apache License, Version 2 (<a href="http://www.apache.org/licenses/LICENSE-2.0.html">http://www.apache.org/licenses/LICENSE-2.0.html</a>). For all other ideas provided on this list, the provider waives all patent and other intellectual property rights inherent in such information.</span></div></blockquote></body></html>