Thanks Tim for your help, I will raise the bug.
--
Clément Delgrange <cl.delgra...@protonmail.com>
‐‐‐‐‐‐‐ Original Message ‐‐‐‐‐‐‐
On Monday 10 December 2018 12:52, Tim Ward <tim.w...@paremus.com> wrote:
> Hi Clément,
>
> You should raise a bug about the JavaDoc/implementation inconsistency in the
> OSGi bugzilla. The StackOverflow question is now answered, hopefully to your
> satisfaction.
>
> Best Regards,
>
> Tim
>
>> On 9 Dec 2018, at 21:35, Clément Delgrange via osgi-dev
>> <osgi-dev@mail.osgi.org> wrote:
>>
>> Hi all,
>>
>> I have two questions related to the OSGi PushStream implementation. The
>> first one is on
>> [Stackoverflow.com](https://stackoverflow.com/questions/53692861/osgi-pushstream-is-slow);
>> the second is the publish method of the SimplePushEventSource says that it
>> throws a IllegalStateException if the source is closed:
>>
>>> /**
>>> * Asynchronously publish an event to this stream and all connected
>>> * {@link PushEventConsumer} instances. When this method returns there is no
>>> * guarantee that all consumers have been notified. Events published by a
>>> * single thread will maintain their relative ordering, however they may be
>>> * interleaved with events from other threads.
>>> *
>>> * @param t
>>> * @throws IllegalStateException if the source is closed
>>> */
>>> void publish(T t);
>>
>> But in the implementation it only returns:
>>
>>> @Override
>>> public void publish(T t) {
>>> enqueueEvent(PushEvent.data(t));
>>> }
>>>
>>> private void enqueueEvent(PushEvent<T> event) {
>>> synchronized (lock) {
>>> if (closed || connected.isEmpty()) {
>>> return;
>>> }
>>> }
>>>
>>> try {
>>> queuePolicy.doOffer(queue, event);
>>> boolean start;
>>> synchronized (lock) {
>>> start = !waitForFinishes && semaphore.tryAcquire();
>>> }
>>> if (start) {
>>> startWorker();
>>> }
>>> } catch (Exception e) {
>>> close(PushEvent.error(e));
>>> throw new IllegalStateException("The queue policy threw an
>>> exception", e);
>>> }
>>> }
>>
>> When the exception is thrown? I have tested with the following code:
>>
>>> source.close();
>>> source.publish( 1 );
>>
>> and effectively it only returns.
>>
>> Thanks
>> --
>> Clément Delgrange <cl.delgra...@protonmail.com>
>>
>> _______________________________________________
>> OSGi Developer Mail List
>> osgi-dev@mail.osgi.org
>> https://mail.osgi.org/mailman/listinfo/osgi-dev
_______________________________________________
OSGi Developer Mail List
osgi-dev@mail.osgi.org
https://mail.osgi.org/mailman/listinfo/osgi-dev