blob: 01704ef078e1c1e581b0d2c3b2ce949f7126f396 [file] [log] [blame]
/*
* Copyright (C) 2009 The Guava Authors
*
* 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.google.common.cache;
import static org.mockito.Mockito.mock;
import static org.mockito.Mockito.verify;
import static org.mockito.Mockito.when;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import java.util.concurrent.ExecutionException;
import junit.framework.TestCase;
/**
* Unit test for {@link ForwardingLoadingCache}.
*
* @author Charles Fry
*/
public class ForwardingLoadingCacheTest extends TestCase {
private LoadingCache<String, Boolean> forward;
private LoadingCache<String, Boolean> mock;
@SuppressWarnings("unchecked") // mock
@Override
public void setUp() throws Exception {
super.setUp();
/*
* Class parameters must be raw, so we can't create a proxy with generic
* type arguments. The created proxy only records calls and returns null, so
* the type is irrelevant at runtime.
*/
mock = mock(LoadingCache.class);
forward =
new ForwardingLoadingCache<String, Boolean>() {
@Override
protected LoadingCache<String, Boolean> delegate() {
return mock;
}
};
}
public void testGet() throws ExecutionException {
when(mock.get("key")).thenReturn(Boolean.TRUE);
assertSame(Boolean.TRUE, forward.get("key"));
}
public void testGetUnchecked() {
when(mock.getUnchecked("key")).thenReturn(Boolean.TRUE);
assertSame(Boolean.TRUE, forward.getUnchecked("key"));
}
public void testGetAll() throws ExecutionException {
when(mock.getAll(ImmutableList.of("key"))).thenReturn(ImmutableMap.of("key", Boolean.TRUE));
assertEquals(ImmutableMap.of("key", Boolean.TRUE), forward.getAll(ImmutableList.of("key")));
}
public void testApply() {
when(mock.apply("key")).thenReturn(Boolean.TRUE);
assertSame(Boolean.TRUE, forward.apply("key"));
}
public void testInvalidate() {
forward.invalidate("key");
verify(mock).invalidate("key");
}
public void testRefresh() throws ExecutionException {
forward.refresh("key");
verify(mock).refresh("key");
}
public void testInvalidateAll() {
forward.invalidateAll();
verify(mock).invalidateAll();
}
public void testSize() {
when(mock.size()).thenReturn(0L);
forward.size();
}
public void testStats() {
when(mock.stats()).thenReturn(null);
assertNull(forward.stats());
}
public void testAsMap() {
when(mock.asMap()).thenReturn(null);
assertNull(forward.asMap());
}
public void testCleanUp() {
forward.cleanUp();
verify(mock).cleanUp();
}
/** Make sure that all methods are forwarded. */
private static class OnlyGet<K, V> extends ForwardingLoadingCache<K, V> {
@Override
protected LoadingCache<K, V> delegate() {
return null;
}
}
}