Hi all,
I am using a file consumer in the batch mode to consume all the files in
a directory.
I aggregate them all together using aggregate(constant(true), new
MyAggregationStrategy()).completionFromBatchConsumer()
And it works just fine.
Now I need to be notified if there is nothing to consume (the directory
is empty). So I use sendEmptyMessageWhenIdle=true
which works just fine by itself.
But if I use both sendEmptyMessageWhenIdle and
completionFromBatchConsumer() the aggregation never completes.
Tested with camel 2.10.0
I found this completion logic in AggregateProcessor.isCompleted(String,
Exchange)
int size = exchange.getProperty(Exchange.BATCH_SIZE, 0,
Integer.class);
if (size > 0 && batchConsumerCounter.intValue() >= size) {
....
}
In other words the aggregate will never complete if there is nothing in
the batch.
Is there an elegant way to aggregate a flow even if the batch is empty?
Thank you!
Max
"This e-mail and any attachments to it (the "Communication") is, unless
otherwise stated, confidential, may contain copyright material and is for the
use only of the intended recipient. If you receive the Communication in error,
please notify the sender immediately by return e-mail, delete the Communication
and the return e-mail, and do not read, copy, retransmit or otherwise deal with
it. Any views expressed in the Communication are those of the individual sender
only, unless expressly stated to be those of Australia and New Zealand Banking
Group Limited ABN 11 005 357 522, or any of its related entities including ANZ
National Bank Limited (together "ANZ"). ANZ does not accept liability in
connection with the integrity of or errors in the Communication, computer
virus, data corruption, interference or delay arising from or in respect of the
Communication."