/** * Licensed to the Apache Software Foundation (ASF) under one or more * contributor license agreements. See the NOTICE file distributed with * this work for additional information regarding copyright ownership. * The ASF licenses this file to You under the Apache License, Version 2.0 * (the "License"); you may not use this file except in compliance with * the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package org.apache.camel.component.jcache; import javax.cache.Cache; import javax.cache.event.CacheEntryEvent; import javax.cache.event.CacheEntryEventFilter; import javax.cache.event.CacheEntryListenerException; import javax.cache.event.EventType; import org.apache.camel.Exchange; import org.apache.camel.Predicate; import org.apache.camel.builder.RouteBuilder; import org.apache.camel.component.mock.MockEndpoint; import org.apache.camel.impl.JndiRegistry; import org.junit.Test; public class JCacheConsumerTest extends JCacheComponentTestSupport { @Override protected JndiRegistry createRegistry() throws Exception { JndiRegistry registry = super.createRegistry(); registry.bind("myFilter", new CacheEntryEventFilter<Object, Object>() { @Override public boolean evaluate(CacheEntryEvent<?, ?> event) throws CacheEntryListenerException { if (event.getEventType() == EventType.REMOVED) { return false; } return !event.getValue().toString().startsWith("to-filter-"); } }); return registry; } @Test public void testFilters() throws Exception { final Cache<Object, Object> cache = getCacheFromEndpoint("jcache://test-cache"); final String key = randomString(); final String val1 = "to-filter-" + randomString(); final String val2 = randomString(); cache.put(key, val1); cache.put(key, val2); cache.remove(key); MockEndpoint mockCreated = getMockEndpoint("mock:created"); mockCreated.expectedMinimumMessageCount(1); mockCreated.expectedHeaderReceived(JCacheConstants.KEY, key); mockCreated.expectedMessagesMatches(new Predicate() { @Override public boolean matches(Exchange exchange) { return exchange.getIn().getBody(String.class).equals(val1); } }); MockEndpoint mockUpdated = getMockEndpoint("mock:updated"); mockUpdated.expectedMinimumMessageCount(1); mockUpdated.expectedHeaderReceived(JCacheConstants.KEY, key); mockUpdated.expectedMessagesMatches(new Predicate() { @Override public boolean matches(Exchange exchange) { return exchange.getIn().getBody(String.class).equals(val2); } }); MockEndpoint mockRemoved = getMockEndpoint("mock:removed"); mockRemoved.expectedMinimumMessageCount(1); mockRemoved.expectedHeaderReceived(JCacheConstants.KEY, key); mockRemoved.expectedMessagesMatches(new Predicate() { @Override public boolean matches(Exchange exchange) { return exchange.getIn().getBody(String.class).equals(val2); } }); MockEndpoint mockMyFilter = getMockEndpoint("mock:my-filter"); mockMyFilter.expectedMinimumMessageCount(1); mockMyFilter.expectedHeaderReceived(JCacheConstants.KEY, key); mockMyFilter.expectedMessagesMatches(new Predicate() { @Override public boolean matches(Exchange exchange) { return exchange.getIn().getBody(String.class).equals(val2); } }); assertMockEndpointsSatisfied(); } @Override protected RouteBuilder createRouteBuilder() throws Exception { return new RouteBuilder() { public void configure() { from("jcache://test-cache?filteredEvents=UPDATED,REMOVED,EXPIRED") .to("mock:created"); from("jcache://test-cache?filteredEvents=CREATED,REMOVED,EXPIRED") .to("mock:updated"); from("jcache://test-cache?filteredEvents=CREATED,UPDATED,EXPIRED") .to("mock:removed"); from("jcache://test-cache?eventFilters=#myFilter") .to("mock:my-filter"); } }; } }