use of org.infinispan.query.test.Person in project infinispan by infinispan.
the class ClusteredListenerWithDslFilterTest method testEventFilterAndConverter.
public void testEventFilterAndConverter() {
QueryFactory qf = Search.getQueryFactory(cache(0));
Query<Object[]> query = qf.create("SELECT name, age FROM " + Person.class.getName() + " WHERE age <= 31");
EntryListener listener = new EntryListener();
for (int i = 0; i < 5; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(i + 30);
Cache<Object, Person> cache = cache(i % NUM_NODES);
Object key = new MagicKey(cache);
cache.put(key, value);
}
// we want our cluster listener to be notified only if the entity matches our query
cache(0).addListener(listener, Search.makeFilter(query), null);
for (int i = 0; i < 10; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(i + 25);
Cache<Object, Person> cache = cache(i % NUM_NODES);
Object key = new MagicKey(cache);
cache.put(key, value);
}
assertEquals(9, listener.results.size());
for (ObjectFilter.FilterResult r : listener.results) {
assertTrue((Integer) r.getProjection()[1] <= 31);
}
cache(0).removeListener(listener);
}
use of org.infinispan.query.test.Person in project infinispan by infinispan.
the class ListenerWithDslFilterProfilingTest method testEventFilterPerformance.
public void testEventFilterPerformance() {
QueryFactory qf = Search.getQueryFactory(cache());
Query<Person> query = qf.create("FROM org.infinispan.query.test.Person WHERE age <= 31");
List<NoOpEntryListener> listeners = new ArrayList<>(NUM_LISTENERS);
for (int i = 0; i < NUM_LISTENERS; i++) {
NoOpEntryListener listener = new NoOpEntryListener();
listeners.add(listener);
cache().addListener(listener, Search.makeFilter(query), null);
}
long startTs = System.nanoTime();
for (int i = 0; i < NUM_ENTRIES; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(i + 25);
cache.put(i, value);
}
long endTs = System.nanoTime();
for (NoOpEntryListener listener : listeners) {
cache().removeListener(listener);
}
log.infof("ListenerWithDslFilterProfilingTest.testEventFilterPerformance took %d us\n", (endTs - startTs) / 1000);
}
use of org.infinispan.query.test.Person in project infinispan by infinispan.
the class ListenerWithDslFilterTest method testEventFilter.
public void testEventFilter() {
for (int i = 0; i < 10; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(99);
cache().put(i, value);
}
assertEquals(10, cache.size());
QueryFactory qf = Search.getQueryFactory(cache());
Query<Person> query = qf.<Person>create("FROM " + Person.class.getName() + " WHERE age <= :ageParam").setParameter("ageParam", 31);
EntryListener listener = new EntryListener();
// we want our cluster listener to be notified only if the entity matches our query
cache().addListener(listener, Search.makeFilter(query), null);
assertTrue(listener.createEvents.isEmpty());
assertTrue(listener.modifyEvents.isEmpty());
for (int i = 0; i < 10; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(i + 25);
cache().put(i, value);
}
assertEquals(10, cache.size());
assertTrue(listener.createEvents.isEmpty());
assertEquals(7, listener.modifyEvents.size());
for (ObjectFilter.FilterResult r : listener.modifyEvents) {
Person p = (Person) r.getInstance();
assertTrue(p.getAge() <= 31);
}
cache().removeListener(listener);
// ensure no more invocations after the listener was removed
listener.createEvents.clear();
listener.modifyEvents.clear();
Person value = new Person();
value.setName("George");
value.setAge(30);
cache().put(-1, value);
assertTrue(listener.createEvents.isEmpty());
assertTrue(listener.modifyEvents.isEmpty());
}
use of org.infinispan.query.test.Person in project infinispan by infinispan.
the class ListenerWithDslFilterTest method testDisallowFullTextQuery.
@Test(expectedExceptions = ParsingException.class, expectedExceptionsMessageRegExp = "ISPN028523: Filters cannot use full-text searches")
public void testDisallowFullTextQuery() {
QueryFactory qf = Search.getQueryFactory(cache());
Query<Person> query = qf.create("FROM " + Person.class.getName() + " WHERE name : 'john'");
cache().addListener(new EntryListener(), Search.makeFilter(query), null);
}
use of org.infinispan.query.test.Person in project infinispan by infinispan.
the class ListenerWithDslFilterTest method testEventFilterAndConverter.
public void testEventFilterAndConverter() {
QueryFactory qf = Search.getQueryFactory(cache());
Query<Object[]> query = qf.create("SELECT name, age FROM " + Person.class.getName() + " WHERE age <= 31");
EntryListener listener = new EntryListener();
// we want our cluster listener to be notified only if the entity matches our query
cache().addListener(listener, Search.makeFilter(query), null);
for (int i = 0; i < 10; ++i) {
Person value = new Person();
value.setName("John");
value.setAge(i + 25);
cache.put(i, value);
}
assertEquals(10, cache.size());
assertEquals(7, listener.createEvents.size());
assertTrue(listener.modifyEvents.isEmpty());
for (ObjectFilter.FilterResult r : listener.createEvents) {
assertNotNull(r.getProjection());
assertEquals(2, r.getProjection().length);
assertTrue((Integer) r.getProjection()[1] <= 31);
}
cache().removeListener(listener);
}
Aggregations