/*
* Copyright 2014-2017 the original author or 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 org.springframework.data.redis.core;
import java.lang.reflect.Method;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.mockito.Mock;
import org.mockito.Mockito;
import org.mockito.junit.MockitoJUnitRunner;
import org.springframework.dao.InvalidDataAccessApiUsageException;
import org.springframework.data.redis.connection.RedisConnection;
import org.springframework.data.redis.connection.RedisConnectionFactory;
import org.springframework.data.redis.core.RedisConnectionUtils.ConnectionSplittingInterceptor;
import org.springframework.util.ClassUtils;
/**
* @author Christoph Strobl
*/
@RunWith(MockitoJUnitRunner.class)
public class ConnectionSplittingInterceptorUnitTests {
private static final Method WRITE_METHOD, READONLY_METHOD;
private ConnectionSplittingInterceptor interceptor;
private @Mock RedisConnectionFactory connectionFactoryMock;
private @Mock RedisConnection freshConnectionMock;
private @Mock RedisConnection boundConnectionMock;
static {
try {
WRITE_METHOD = ClassUtils.getMethod(RedisConnection.class, "expire", byte[].class, long.class);
READONLY_METHOD = ClassUtils.getMethod(RedisConnection.class, "keys", byte[].class);
} catch (Exception e) {
throw new RuntimeException(e);
}
}
@Before
public void setUp() {
interceptor = new ConnectionSplittingInterceptor(connectionFactoryMock);
Mockito.when(connectionFactoryMock.getConnection()).thenReturn(freshConnectionMock);
}
@Test // DATAREDIS-73
public void interceptorShouldRequestFreshConnectionForReadonlyCommand() throws Throwable {
interceptor.intercept(boundConnectionMock, READONLY_METHOD, new Object[] { new byte[] {} }, null);
Mockito.verify(connectionFactoryMock, Mockito.times(1)).getConnection();
Mockito.verifyZeroInteractions(boundConnectionMock);
}
@Test // DATAREDIS-73
public void interceptorShouldUseBoundConnectionForWriteOperations() throws Throwable {
interceptor.intercept(boundConnectionMock, WRITE_METHOD, new Object[] { new byte[] {}, 0L }, null);
Mockito.verify(boundConnectionMock, Mockito.times(1)).expire(Mockito.any(byte[].class), Mockito.anyLong());
Mockito.verifyZeroInteractions(connectionFactoryMock);
}
@SuppressWarnings("unchecked")
@Test(expected = InvalidDataAccessApiUsageException.class) // DATAREDIS-73
public void interceptorShouldNotWrapException() throws Throwable {
Mockito.when(freshConnectionMock.keys(Mockito.any(byte[].class))).thenThrow(
InvalidDataAccessApiUsageException.class);
interceptor.intercept(boundConnectionMock, READONLY_METHOD, new Object[] { new byte[] {} }, null);
}
}