- * Runs an embedded Redis instance on a random available port.This is only necessary - * sincewe do not want users to have to setup a Redis instance. In a production - * environment, this would not be used since a Redis Server would be setup. - *
- *- * The port being used can be identified by using {@literal @RedisServerPort} on a Spring - * Bean. For example: - *
- * - *
- * {@literal @Configuration}
- * {@literal @EnableEmbeddedRedis}
- * public class RedisHttpSessionConfig {
- *
- * {@literal @Bean}
- * public JedisConnectionFactory connectionFactory({@literal @RedisServerPort} int port) throws Exception {
- * JedisConnectionFactory connection = new JedisConnectionFactory();
- * connection.setPort(port);
- * return connection;
- * }
- *
- * }
- *
- *
- * See spring-projects/spring-session/issues/121 for details on exposing embedded Redis
- * support.
- *
- * @author Rob Winch
- * @see RedisServerPort
- *
- */
-@Retention(value=java.lang.annotation.RetentionPolicy.RUNTIME)
-@Target(value={java.lang.annotation.ElementType.TYPE})
-@Documented
-@Import(EmbeddedRedisConfiguration.class)
-@Configuration
-public @interface EnableEmbeddedRedis {}
diff --git a/samples/spring-embedded-redis/src/main/java/org/springframework/session/redis/embedded/RedisServerPort.java b/samples/spring-embedded-redis/src/main/java/org/springframework/session/redis/embedded/RedisServerPort.java
deleted file mode 100644
index 480ddc50..00000000
--- a/samples/spring-embedded-redis/src/main/java/org/springframework/session/redis/embedded/RedisServerPort.java
+++ /dev/null
@@ -1,50 +0,0 @@
-/*
- * Copyright 2002-2015 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.session.redis.embedded;
-
-import java.lang.annotation.Documented;
-import java.lang.annotation.ElementType;
-import java.lang.annotation.Retention;
-import java.lang.annotation.RetentionPolicy;
-import java.lang.annotation.Target;
-
-import org.springframework.beans.factory.annotation.Value;
-
-/**
- * A convenience for finding the Redis Server port when using {@link EnableEmbeddedRedis}. For example:
- *
- *
- * {@literal @Configuration}
- * {@literal @EnableEmbeddedRedis}
- * public class RedisHttpSessionConfig {
- *
- * {@literal @Bean}
- * public JedisConnectionFactory connectionFactory({@literal @RedisServerPort} int port) throws Exception {
- * JedisConnectionFactory connection = new JedisConnectionFactory();
- * connection.setPort(port);
- * return connection;
- * }
- *
- * }
- *
- *
- * @author Rob Winch
- */
-@Target({ElementType.FIELD, ElementType.METHOD, ElementType.PARAMETER, ElementType.ANNOTATION_TYPE})
-@Retention(RetentionPolicy.RUNTIME)
-@Documented
-@Value("${"+EmbeddedRedisConfiguration.SERVER_PORT_PROP_NAME+"}")
-public @interface RedisServerPort { }
diff --git a/samples/users/build.gradle b/samples/users/build.gradle
index f8215de3..9fb8178e 100644
--- a/samples/users/build.gradle
+++ b/samples/users/build.gradle
@@ -8,7 +8,6 @@ sonarRunner {
dependencies {
compile project(':spring-session-data-redis'),
- project(':samples:spring-embedded-redis'),
"org.springframework:spring-web:$springVersion",
jstlDependencies
diff --git a/samples/users/src/main/java/sample/Config.java b/samples/users/src/main/java/sample/Config.java
index 93d1ed74..98c25753 100644
--- a/samples/users/src/main/java/sample/Config.java
+++ b/samples/users/src/main/java/sample/Config.java
@@ -19,24 +19,19 @@ import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
-import org.springframework.session.redis.embedded.EnableEmbeddedRedis;
-import org.springframework.session.redis.embedded.RedisServerPort;
/**
* @author Rob Winch
*/
-@EnableEmbeddedRedis
// tag::class[]
@Configuration
@EnableRedisHttpSession
public class Config {
@Bean
- public JedisConnectionFactory connectionFactory(@RedisServerPort int port) {
- JedisConnectionFactory connection = new JedisConnectionFactory();
- connection.setPort(port);
- return connection;
+ public JedisConnectionFactory connectionFactory() {
+ return new JedisConnectionFactory();
}
}
// end::class[]
\ No newline at end of file
diff --git a/samples/websocket/build.gradle b/samples/websocket/build.gradle
index 292eccc2..b535f177 100644
--- a/samples/websocket/build.gradle
+++ b/samples/websocket/build.gradle
@@ -18,7 +18,6 @@ group = 'samples'
dependencies {
compile project(':spring-session-data-redis'),
- project(':samples:spring-embedded-redis'),
"org.springframework.boot:spring-boot-starter-web",
"org.springframework.boot:spring-boot-starter-data-jpa",
"org.springframework.boot:spring-boot-starter-thymeleaf",
diff --git a/samples/websocket/src/main/java/sample/config/DataSourceConfig.java b/samples/websocket/src/main/java/sample/config/DataSourceConfig.java
index 05c16b6b..7c1f60f1 100644
--- a/samples/websocket/src/main/java/sample/config/DataSourceConfig.java
+++ b/samples/websocket/src/main/java/sample/config/DataSourceConfig.java
@@ -22,7 +22,6 @@ import org.springframework.context.annotation.Configuration;
import org.springframework.data.redis.connection.jedis.JedisConnectionFactory;
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseBuilder;
import org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType;
-import org.springframework.session.redis.embedded.RedisServerPort;
@Configuration
public class DataSourceConfig {
@@ -34,9 +33,7 @@ public class DataSourceConfig {
}
@Bean
- public JedisConnectionFactory connectionFactory(@RedisServerPort int port) {
- JedisConnectionFactory connection = new JedisConnectionFactory(); // <3>
- connection.setPort(port);
- return connection;
+ public JedisConnectionFactory connectionFactory() {
+ return new JedisConnectionFactory();
}
}
diff --git a/samples/websocket/src/main/java/sample/config/WebSecurityConfig.java b/samples/websocket/src/main/java/sample/config/WebSecurityConfig.java
index 508d26dd..4f787e43 100644
--- a/samples/websocket/src/main/java/sample/config/WebSecurityConfig.java
+++ b/samples/websocket/src/main/java/sample/config/WebSecurityConfig.java
@@ -27,12 +27,10 @@ import org.springframework.security.core.userdetails.UserDetailsService;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.data.repository.query.SecurityEvaluationContextExtension;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
-import org.springframework.session.redis.embedded.EnableEmbeddedRedis;
@Configuration
@EnableWebSecurity
@EnableGlobalMethodSecurity(prePostEnabled = true)
-@EnableEmbeddedRedis
// tag::enable-redis-httpsession[]
@EnableRedisHttpSession//(maxInactiveIntervalInSeconds = 60)
public class WebSecurityConfig
diff --git a/settings.gradle b/settings.gradle
index 5ef8d7a0..60f0c6e5 100644
--- a/settings.gradle
+++ b/settings.gradle
@@ -3,7 +3,6 @@ rootProject.name = 'spring-session-build'
include 'docs'
include 'samples:boot'
-include 'samples:spring-embedded-redis'
include 'samples:hazelcast'
include 'samples:httpsession'
include 'samples:httpsession-xml'
diff --git a/spring-session/build.gradle b/spring-session/build.gradle
index bbf14521..55851d9d 100644
--- a/spring-session/build.gradle
+++ b/spring-session/build.gradle
@@ -20,8 +20,7 @@ dependencies {
"org.springframework:spring-messaging:$springVersion",
"org.springframework:spring-websocket:$springVersion"
provided "javax.servlet:javax.servlet-api:$servletApiVersion"
- integrationTestCompile project(':samples:spring-embedded-redis'),
- "redis.clients:jedis:2.4.1",
+ integrationTestCompile "redis.clients:jedis:2.4.1",
"org.apache.commons:commons-pool2:2.2"
testCompile "junit:junit:$junitVersion",
diff --git a/spring-session/src/integration-test/java/org/springframework/session/data/redis/RedisOperationsSessionRepositoryITests.java b/spring-session/src/integration-test/java/org/springframework/session/data/redis/RedisOperationsSessionRepositoryITests.java
index e614a636..6a185c6d 100644
--- a/spring-session/src/integration-test/java/org/springframework/session/data/redis/RedisOperationsSessionRepositoryITests.java
+++ b/spring-session/src/integration-test/java/org/springframework/session/data/redis/RedisOperationsSessionRepositoryITests.java
@@ -34,8 +34,6 @@ import org.springframework.session.Session;
import org.springframework.session.SessionRepository;
import org.springframework.session.data.redis.config.annotation.web.http.EnableRedisHttpSession;
import org.springframework.session.events.SessionDestroyedEvent;
-import org.springframework.session.redis.embedded.EnableEmbeddedRedis;
-import org.springframework.session.redis.embedded.RedisServerPort;
import org.springframework.test.context.ContextConfiguration;
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
import org.springframework.test.context.web.WebAppConfiguration;
@@ -124,12 +122,10 @@ public class RedisOperationsSessionRepositoryITests