Search in sources :

Example 1 with Person

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);
}
Also used : QueryFactory(org.infinispan.query.dsl.QueryFactory) ObjectFilter(org.infinispan.objectfilter.ObjectFilter) Person(org.infinispan.query.test.Person) MagicKey(org.infinispan.distribution.MagicKey)

Example 2 with Person

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);
}
Also used : QueryFactory(org.infinispan.query.dsl.QueryFactory) ArrayList(java.util.ArrayList) Person(org.infinispan.query.test.Person)

Example 3 with Person

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());
}
Also used : QueryFactory(org.infinispan.query.dsl.QueryFactory) ObjectFilter(org.infinispan.objectfilter.ObjectFilter) Person(org.infinispan.query.test.Person)

Example 4 with Person

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);
}
Also used : QueryFactory(org.infinispan.query.dsl.QueryFactory) Person(org.infinispan.query.test.Person) SingleCacheManagerTest(org.infinispan.test.SingleCacheManagerTest) Test(org.testng.annotations.Test)

Example 5 with Person

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);
}
Also used : QueryFactory(org.infinispan.query.dsl.QueryFactory) ObjectFilter(org.infinispan.objectfilter.ObjectFilter) Person(org.infinispan.query.test.Person)

Aggregations

Person (org.infinispan.query.test.Person)82 QueryFactory (org.infinispan.query.dsl.QueryFactory)21 Test (org.testng.annotations.Test)11 ObjectFilter (org.infinispan.objectfilter.ObjectFilter)6 SingleCacheManagerTest (org.infinispan.test.SingleCacheManagerTest)6 TransactionManager (javax.transaction.TransactionManager)5 MultipleCacheManagersTest (org.infinispan.test.MultipleCacheManagersTest)5 MagicKey (org.infinispan.distribution.MagicKey)3 AnotherGrassEater (org.infinispan.query.test.AnotherGrassEater)3 ArrayList (java.util.ArrayList)2 ConfigurationBuilder (org.infinispan.configuration.cache.ConfigurationBuilder)2 NumberFormat (java.text.NumberFormat)1 HashMap (java.util.HashMap)1 Set (java.util.Set)1 AtomicInteger (java.util.concurrent.atomic.AtomicInteger)1 MBeanServer (javax.management.MBeanServer)1 ObjectName (javax.management.ObjectName)1 RollbackException (javax.transaction.RollbackException)1 CacheException (org.infinispan.commons.CacheException)1 CacheEntry (org.infinispan.container.entries.CacheEntry)1