/* * 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.ignite.internal.processors.cache.query.continuous; import java.io.Externalizable; import java.io.IOException; import java.io.ObjectInput; import java.io.ObjectOutput; import javax.cache.configuration.Factory; import javax.cache.configuration.FactoryBuilder; import javax.cache.event.CacheEntryEvent; import javax.cache.event.CacheEntryEventFilter; import org.apache.ignite.cache.CacheEntryEventSerializableFilter; import org.apache.ignite.lang.IgniteAsyncCallback; import org.jetbrains.annotations.NotNull; /** * */ public class CacheContinuousQueryFactoryAsyncFilterRandomOperationTest extends CacheContinuousQueryFactoryFilterRandomOperationTest { /** {@inheritDoc} */ @NotNull @Override protected Factory<? extends CacheEntryEventFilter<QueryTestKey, QueryTestValue>> createFilterFactory() { return new AsyncFilterFactory(); } /** * */ @IgniteAsyncCallback protected static class NonSerializableAsyncFilter implements CacheEntryEventSerializableFilter<QueryTestKey, QueryTestValue>, Externalizable { /** */ public NonSerializableAsyncFilter() { // No-op. } /** {@inheritDoc} */ @Override public boolean evaluate(CacheEntryEvent<? extends QueryTestKey, ? extends QueryTestValue> evt) { assertTrue("Failed. Current thread name: " + Thread.currentThread().getName(), Thread.currentThread().getName().contains("callback-")); assertFalse("Failed. Current thread name: " + Thread.currentThread().getName(), Thread.currentThread().getName().contains("sys-")); return isAccepted(evt.getValue()); } /** {@inheritDoc} */ @Override public void writeExternal(ObjectOutput out) throws IOException { fail("Entry filter should not be marshaled."); } /** {@inheritDoc} */ @Override public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { fail("Entry filter should not be marshaled."); } /** * @param val Value. * @return {@code True} if value is even. */ public static boolean isAccepted(QueryTestValue val) { return val == null || val.val1 % 2 == 0; } } /** * */ protected static class AsyncFilterFactory implements Factory<NonSerializableAsyncFilter> { /** {@inheritDoc} */ @Override public NonSerializableAsyncFilter create() { return new NonSerializableAsyncFilter(); } } /** {@inheritDoc} */ @Override protected Factory<? extends CacheEntryEventFilter<QueryTestKey, QueryTestValue>> noOpFilterFactory() { return FactoryBuilder.factoryOf(NoopAsyncFilter.class); } /** * */ @IgniteAsyncCallback protected static class NoopAsyncFilter implements CacheEntryEventSerializableFilter<QueryTestKey, QueryTestValue>, Externalizable { /** */ public NoopAsyncFilter() { // No-op. } /** {@inheritDoc} */ @Override public boolean evaluate(CacheEntryEvent<? extends QueryTestKey, ? extends QueryTestValue> evt) { assertTrue("Failed. Current thread name: " + Thread.currentThread().getName(), Thread.currentThread().getName().contains("callback-")); assertFalse("Failed. Current thread name: " + Thread.currentThread().getName(), Thread.currentThread().getName().contains("sys-")); return true; } /** {@inheritDoc} */ @Override public void writeExternal(ObjectOutput out) throws IOException { // No-op. } /** {@inheritDoc} */ @Override public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException { // No-op. } } }