use of com.hazelcast.core.ItemEvent in project camel by apache.
the class HazelcastQueueConsumerTest method add.
@Test
@SuppressWarnings("unchecked")
public void add() throws InterruptedException {
MockEndpoint out = getMockEndpoint("mock:added");
out.expectedMessageCount(1);
final ItemEvent<String> event = new ItemEvent<String>("foo", ItemEventType.ADDED, "foo", null);
argument.getValue().itemAdded(event);
assertMockEndpointsSatisfied(2000, TimeUnit.MILLISECONDS);
this.checkHeaders(out.getExchanges().get(0).getIn().getHeaders(), HazelcastConstants.ADDED);
}
use of com.hazelcast.core.ItemEvent in project hazelcast by hazelcast.
the class ListAddListenerMessageTask method createItemListener.
private ItemListener createItemListener(final ClientEndpoint endpoint, final Data partitionKey) {
return new ItemListener() {
@Override
public void itemAdded(ItemEvent item) {
send(item);
}
@Override
public void itemRemoved(ItemEvent item) {
send(item);
}
private void send(ItemEvent event) {
if (endpoint.isAlive()) {
if (!(event instanceof DataAwareItemEvent)) {
throw new IllegalArgumentException("Expecting: DataAwareItemEvent, Found: " + event.getClass().getSimpleName());
}
DataAwareItemEvent dataAwareItemEvent = (DataAwareItemEvent) event;
Data item = dataAwareItemEvent.getItemData();
ClientMessage clientMessage = ListAddListenerCodec.encodeItemEvent(item, event.getMember().getUuid(), event.getEventType().getType());
sendClientMessage(partitionKey, clientMessage);
}
}
};
}
use of com.hazelcast.core.ItemEvent in project hazelcast by hazelcast.
the class SetAddListenerMessageTask method createItemListener.
private ItemListener createItemListener(final ClientEndpoint endpoint, final Data partitionKey) {
return new ItemListener() {
@Override
public void itemAdded(ItemEvent item) {
send(item);
}
@Override
public void itemRemoved(ItemEvent item) {
send(item);
}
private void send(ItemEvent event) {
if (endpoint.isAlive()) {
if (!(event instanceof DataAwareItemEvent)) {
throw new IllegalArgumentException("Expecting: DataAwareItemEvent, Found: " + event.getClass().getSimpleName());
}
DataAwareItemEvent dataAwareItemEvent = (DataAwareItemEvent) event;
Data item = dataAwareItemEvent.getItemData();
ClientMessage clientMessage = SetAddListenerCodec.encodeItemEvent(item, event.getMember().getUuid(), event.getEventType().getType());
sendClientMessage(partitionKey, clientMessage);
}
}
};
}
use of com.hazelcast.core.ItemEvent in project hazelcast by hazelcast.
the class ClientSetTest method testListener.
@Test
public void testListener() throws Exception {
final CountDownLatch latch = new CountDownLatch(6);
ItemListener<String> listener = new ItemListener<String>() {
public void itemAdded(ItemEvent<String> itemEvent) {
latch.countDown();
}
public void itemRemoved(ItemEvent<String> item) {
}
};
String registrationId = set.addItemListener(listener, true);
new Thread() {
public void run() {
for (int i = 0; i < 5; i++) {
set.add("item" + i);
}
set.add("done");
}
}.start();
assertTrue(latch.await(20, TimeUnit.SECONDS));
set.removeItemListener(registrationId);
}
Aggregations