/*
* Copyright (c) 2008-2017, Hazelcast, Inc. All Rights Reserved.
*
* Licensed 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 com.hazelcast.internal.adapter;
import com.hazelcast.cache.ICache;
import com.hazelcast.cache.impl.HazelcastServerCachingProvider;
import com.hazelcast.config.CacheConfig;
import com.hazelcast.config.CacheConfiguration;
import com.hazelcast.core.HazelcastInstance;
import com.hazelcast.test.HazelcastParallelClassRunner;
import com.hazelcast.test.HazelcastTestSupport;
import com.hazelcast.test.TestHazelcastInstanceFactory;
import com.hazelcast.test.annotation.ParallelTest;
import com.hazelcast.test.annotation.QuickTest;
import org.junit.Before;
import org.junit.Test;
import org.junit.experimental.categories.Category;
import org.junit.runner.RunWith;
import javax.cache.CacheManager;
import javax.cache.configuration.FactoryBuilder;
import javax.cache.processor.EntryProcessorResult;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.Future;
import static com.hazelcast.cache.impl.HazelcastServerCachingProvider.createCachingProvider;
import static java.util.Arrays.asList;
import static java.util.Collections.singleton;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertTrue;
@RunWith(HazelcastParallelClassRunner.class)
@Category({QuickTest.class, ParallelTest.class})
public class ICacheDataStructureAdapterTest extends HazelcastTestSupport {
private ICache<Integer, String> cache;
private ICache<Integer, String> cacheWithLoader;
private ICacheDataStructureAdapter<Integer, String> adapter;
private ICacheDataStructureAdapter<Integer, String> adapterWithLoader;
@Before
public void setUp() {
TestHazelcastInstanceFactory factory = createHazelcastInstanceFactory();
HazelcastInstance hazelcastInstance = factory.newHazelcastInstance();
HazelcastServerCachingProvider cachingProvider = createCachingProvider(hazelcastInstance);
CacheManager cacheManager = cachingProvider.getCacheManager();
CacheConfig<Integer, String> cacheConfig = new CacheConfig<Integer, String>();
CacheConfiguration<Integer, String> cacheConfigWithLoader = new CacheConfig<Integer, String>()
.setReadThrough(true)
.setCacheLoaderFactory(FactoryBuilder.factoryOf(ICacheCacheLoader.class));
cache = (ICache<Integer, String>) cacheManager.createCache("CacheDataStructureAdapterTest", cacheConfig);
cacheWithLoader = (ICache<Integer, String>) cacheManager.createCache("CacheDataStructureAdapterLoaderTest",
cacheConfigWithLoader);
adapter = new ICacheDataStructureAdapter<Integer, String>(cache);
adapterWithLoader = new ICacheDataStructureAdapter<Integer, String>(cacheWithLoader);
}
@Test
public void testSize() {
cache.put(23, "foo");
cache.put(42, "bar");
assertEquals(2, adapter.size());
}
@Test
public void testGet() {
cache.put(42, "foobar");
String result = adapter.get(42);
assertEquals("foobar", result);
}
@Test
public void testGetAsync() throws Exception {
cache.put(42, "foobar");
Future<String> future = adapter.getAsync(42);
String result = future.get();
assertEquals("foobar", result);
}
@Test
public void testSet() {
adapter.set(23, "test");
assertEquals("test", cache.get(23));
}
@Test
public void testPut() {
cache.put(42, "oldValue");
String oldValue = adapter.put(42, "newValue");
assertEquals("oldValue", oldValue);
assertEquals("newValue", cache.get(42));
}
@Test
public void testPutIfAbsent() {
cache.put(42, "oldValue");
assertTrue(adapter.putIfAbsent(23, "newValue"));
assertFalse(adapter.putIfAbsent(42, "newValue"));
assertEquals("newValue", cache.get(23));
assertEquals("oldValue", cache.get(42));
}
@Test
public void testPutIfAbsentAsync() throws Exception {
cache.put(42, "oldValue");
assertTrue(adapter.putIfAbsentAsync(23, "newValue").get());
assertFalse(adapter.putIfAbsentAsync(42, "newValue").get());
assertEquals("newValue", cache.get(23));
assertEquals("oldValue", cache.get(42));
}
@Test
public void testReplace() {
cache.put(42, "oldValue");
String oldValue = adapter.replace(42, "newValue");
assertEquals("oldValue", oldValue);
assertEquals("newValue", cache.get(42));
}
@Test
public void testReplaceWithOldValue() {
cache.put(42, "oldValue");
assertFalse(adapter.replace(42, "foobar", "newValue"));
assertTrue(adapter.replace(42, "oldValue", "newValue"));
assertEquals("newValue", cache.get(42));
}
@Test
public void testRemove() {
cache.put(23, "value-23");
assertTrue(cache.containsKey(23));
adapter.remove(23);
assertFalse(cache.containsKey(23));
}
@Test
public void testRemoveWithOldValue() {
cache.put(23, "value-23");
assertTrue(cache.containsKey(23));
assertFalse(adapter.remove(23, "foobar"));
assertTrue(adapter.remove(23, "value-23"));
assertFalse(cache.containsKey(23));
}
@Test
public void testRemoveAsync() throws Exception {
cache.put(23, "value-23");
assertTrue(cache.containsKey(23));
String value = adapter.removeAsync(23).get();
assertEquals("value-23", value);
assertFalse(cache.containsKey(23));
}
@Test
public void testInvoke() {
cache.put(23, "value-23");
cache.put(42, "value-42");
String result = adapter.invoke(23, new ICacheReplaceEntryProcessor(), "value", "newValue");
assertEquals("newValue-23", result);
assertEquals("newValue-23", cache.get(23));
assertEquals("value-42", cache.get(42));
}
@Test(expected = MethodNotAvailableException.class)
public void testExecuteOnKey() {
adapter.executeOnKey(23, new IMapReplaceEntryProcessor("value", "newValue"));
}
@Test(expected = MethodNotAvailableException.class)
public void testExecuteOnKeys() {
Set<Integer> keys = new HashSet<Integer>(singleton(23));
adapter.executeOnKeys(keys, new IMapReplaceEntryProcessor("value", "newValue"));
}
@Test
public void testContainsKey() {
cache.put(23, "value-23");
assertTrue(adapter.containsKey(23));
assertFalse(adapter.containsKey(42));
}
@Test(expected = MethodNotAvailableException.class)
public void testLoadAll() {
adapterWithLoader.loadAll(true);
}
@Test(expected = MethodNotAvailableException.class)
public void testLoadAllWithKeys() {
adapterWithLoader.loadAll(Collections.<Integer>emptySet(), true);
}
@Test
public void testLoadAllWithListener() {
ICacheCompletionListener listener = new ICacheCompletionListener();
cacheWithLoader.put(23, "value-23");
adapterWithLoader.loadAll(Collections.singleton(23), true, listener);
listener.await();
assertEquals("newValue-23", cacheWithLoader.get(23));
}
@Test
public void testGetAll() {
cache.put(23, "value-23");
cache.put(42, "value-42");
Map<Integer, String> expectedResult = new HashMap<Integer, String>();
expectedResult.put(23, "value-23");
expectedResult.put(42, "value-42");
Map<Integer, String> result = adapter.getAll(expectedResult.keySet());
assertEquals(expectedResult, result);
}
@Test
public void testPutAll() {
Map<Integer, String> expectedResult = new HashMap<Integer, String>();
expectedResult.put(23, "value-23");
expectedResult.put(42, "value-42");
adapter.putAll(expectedResult);
assertEquals(expectedResult.size(), cache.size());
for (Integer key : expectedResult.keySet()) {
assertTrue(cache.containsKey(key));
}
}
@Test
public void testRemoveAll() {
cache.put(23, "value-23");
cache.put(42, "value-42");
adapter.removeAll();
assertEquals(0, cache.size());
}
@Test
public void testRemoveAllWithKeys() {
cache.put(23, "value-23");
cache.put(42, "value-42");
adapter.removeAll(singleton(42));
assertEquals(1, cache.size());
assertTrue(cache.containsKey(23));
assertFalse(cache.containsKey(42));
}
@Test
public void testInvokeAll() {
cache.put(23, "value-23");
cache.put(42, "value-42");
cache.put(65, "value-65");
Set<Integer> keys = new HashSet<Integer>(asList(23, 65, 88));
Map<Integer, EntryProcessorResult<String>> resultMap = adapter.invokeAll(keys, new ICacheReplaceEntryProcessor(),
"value", "newValue");
assertEquals(2, resultMap.size());
assertEquals("newValue-23", resultMap.get(23).get());
assertEquals("newValue-65", resultMap.get(65).get());
assertEquals("newValue-23", cache.get(23));
assertEquals("value-42", cache.get(42));
assertEquals("newValue-65", cache.get(65));
assertNull(cache.get(88));
}
@Test
public void testClear() {
cache.put(23, "foobar");
adapter.clear();
assertEquals(0, cache.size());
}
@Test
public void testDestroy() {
adapter.destroy();
assertTrue(cache.isDestroyed());
}
@Test(expected = MethodNotAvailableException.class)
public void testGetLocalMapStats() {
adapter.getLocalMapStats();
}
}