Refine Spring Social auto-configuration
Refine auto-configuration for Spring Social to: - Only auto-configure FB/Twitter/LinkedIn if the `app-id` property is set. - Only configure ConnectController and ProviderSignInController if there is a ConnectionFactoryLocator. - Auto-configure Spring Social's SpringSocialDialect for Thymeleaf if Thymeleaf is present. - Added several tests around Spring Social auto-configuration. Fixes gh-1118
This commit is contained in:
parent
179e1558f6
commit
46c46dbd0c
|
@ -17,6 +17,7 @@
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
||||||
|
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||||
|
@ -29,6 +30,7 @@ import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.context.annotation.Scope;
|
import org.springframework.context.annotation.Scope;
|
||||||
import org.springframework.context.annotation.ScopedProxyMode;
|
import org.springframework.context.annotation.ScopedProxyMode;
|
||||||
import org.springframework.social.config.annotation.EnableSocial;
|
import org.springframework.social.config.annotation.EnableSocial;
|
||||||
|
import org.springframework.social.config.annotation.SocialConfigurerAdapter;
|
||||||
import org.springframework.social.connect.Connection;
|
import org.springframework.social.connect.Connection;
|
||||||
import org.springframework.social.connect.ConnectionFactory;
|
import org.springframework.social.connect.ConnectionFactory;
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
import org.springframework.social.connect.ConnectionRepository;
|
||||||
|
@ -46,7 +48,9 @@ import org.springframework.web.servlet.View;
|
||||||
* @since 1.1.0
|
* @since 1.1.0
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@ConditionalOnClass({ FacebookConnectionFactory.class })
|
@ConditionalOnClass({ SocialConfigurerAdapter.class, FacebookConnectionFactory.class })
|
||||||
|
@ConditionalOnProperty(prefix = "spring.social.facebook.", value = "app-id")
|
||||||
|
@AutoConfigureBefore(SocialWebAutoConfiguration.class)
|
||||||
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
||||||
public class FacebookAutoConfiguration {
|
public class FacebookAutoConfiguration {
|
||||||
|
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
||||||
|
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||||
|
@ -29,6 +30,7 @@ import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.context.annotation.Scope;
|
import org.springframework.context.annotation.Scope;
|
||||||
import org.springframework.context.annotation.ScopedProxyMode;
|
import org.springframework.context.annotation.ScopedProxyMode;
|
||||||
import org.springframework.social.config.annotation.EnableSocial;
|
import org.springframework.social.config.annotation.EnableSocial;
|
||||||
|
import org.springframework.social.config.annotation.SocialConfigurerAdapter;
|
||||||
import org.springframework.social.connect.Connection;
|
import org.springframework.social.connect.Connection;
|
||||||
import org.springframework.social.connect.ConnectionFactory;
|
import org.springframework.social.connect.ConnectionFactory;
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
import org.springframework.social.connect.ConnectionRepository;
|
||||||
|
@ -45,7 +47,9 @@ import org.springframework.web.servlet.View;
|
||||||
* @since 1.1.0
|
* @since 1.1.0
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@ConditionalOnClass({ LinkedInConnectionFactory.class })
|
@ConditionalOnClass({ SocialConfigurerAdapter.class, LinkedInConnectionFactory.class })
|
||||||
|
@ConditionalOnProperty(prefix = "spring.social.linkedin.", value = "app-id")
|
||||||
|
@AutoConfigureBefore(SocialWebAutoConfiguration.class)
|
||||||
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
||||||
public class LinkedInAutoConfiguration {
|
public class LinkedInAutoConfiguration {
|
||||||
|
|
||||||
|
@ -69,7 +73,7 @@ public class LinkedInAutoConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
@ConditionalOnMissingBean(LinkedInConnectionFactory.class)
|
@ConditionalOnMissingBean(LinkedIn.class)
|
||||||
@Scope(value = "request", proxyMode = ScopedProxyMode.INTERFACES)
|
@Scope(value = "request", proxyMode = ScopedProxyMode.INTERFACES)
|
||||||
public LinkedIn linkedin(ConnectionRepository repository) {
|
public LinkedIn linkedin(ConnectionRepository repository) {
|
||||||
Connection<LinkedIn> connection = repository
|
Connection<LinkedIn> connection = repository
|
||||||
|
|
|
@ -16,7 +16,6 @@
|
||||||
|
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
|
||||||
import org.springframework.boot.bind.RelaxedPropertyResolver;
|
import org.springframework.boot.bind.RelaxedPropertyResolver;
|
||||||
import org.springframework.context.EnvironmentAware;
|
import org.springframework.context.EnvironmentAware;
|
||||||
import org.springframework.core.env.Environment;
|
import org.springframework.core.env.Environment;
|
||||||
|
@ -31,7 +30,6 @@ import org.springframework.social.connect.ConnectionFactory;
|
||||||
* @author Phillip Webb
|
* @author Phillip Webb
|
||||||
* @since 1.1.0
|
* @since 1.1.0
|
||||||
*/
|
*/
|
||||||
@ConditionalOnClass(SocialConfigurerAdapter.class)
|
|
||||||
abstract class SocialAutoConfigurerAdapter extends SocialConfigurerAdapter implements
|
abstract class SocialAutoConfigurerAdapter extends SocialConfigurerAdapter implements
|
||||||
EnvironmentAware {
|
EnvironmentAware {
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,7 @@ import java.util.List;
|
||||||
|
|
||||||
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
||||||
|
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnBean;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
||||||
|
@ -27,6 +28,7 @@ import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingClass;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnWebApplication;
|
||||||
|
import org.springframework.boot.autoconfigure.thymeleaf.ThymeleafAutoConfiguration;
|
||||||
import org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration;
|
import org.springframework.boot.autoconfigure.web.WebMvcAutoConfiguration;
|
||||||
import org.springframework.context.annotation.Bean;
|
import org.springframework.context.annotation.Bean;
|
||||||
import org.springframework.context.annotation.Configuration;
|
import org.springframework.context.annotation.Configuration;
|
||||||
|
@ -45,10 +47,12 @@ import org.springframework.social.connect.web.DisconnectInterceptor;
|
||||||
import org.springframework.social.connect.web.ProviderSignInController;
|
import org.springframework.social.connect.web.ProviderSignInController;
|
||||||
import org.springframework.social.connect.web.ProviderSignInInterceptor;
|
import org.springframework.social.connect.web.ProviderSignInInterceptor;
|
||||||
import org.springframework.social.connect.web.SignInAdapter;
|
import org.springframework.social.connect.web.SignInAdapter;
|
||||||
|
import org.springframework.social.connect.web.thymeleaf.SpringSocialDialect;
|
||||||
import org.springframework.util.Assert;
|
import org.springframework.util.Assert;
|
||||||
import org.springframework.util.CollectionUtils;
|
import org.springframework.util.CollectionUtils;
|
||||||
import org.springframework.web.servlet.ViewResolver;
|
import org.springframework.web.servlet.ViewResolver;
|
||||||
import org.springframework.web.servlet.view.BeanNameViewResolver;
|
import org.springframework.web.servlet.view.BeanNameViewResolver;
|
||||||
|
import org.thymeleaf.spring4.SpringTemplateEngine;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* {@link EnableAutoConfiguration Auto-configuration} for Spring Social's web connection
|
* {@link EnableAutoConfiguration Auto-configuration} for Spring Social's web connection
|
||||||
|
@ -59,6 +63,8 @@ import org.springframework.web.servlet.view.BeanNameViewResolver;
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@ConditionalOnClass({ ConnectController.class, SocialConfigurerAdapter.class })
|
@ConditionalOnClass({ ConnectController.class, SocialConfigurerAdapter.class })
|
||||||
|
@ConditionalOnBean({ ConnectionFactoryLocator.class, UsersConnectionRepository.class })
|
||||||
|
@AutoConfigureBefore(ThymeleafAutoConfiguration.class)
|
||||||
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
||||||
public class SocialWebAutoConfiguration {
|
public class SocialWebAutoConfiguration {
|
||||||
|
|
||||||
|
@ -119,7 +125,7 @@ public class SocialWebAutoConfiguration {
|
||||||
@Configuration
|
@Configuration
|
||||||
@EnableSocial
|
@EnableSocial
|
||||||
@ConditionalOnWebApplication
|
@ConditionalOnWebApplication
|
||||||
@ConditionalOnMissingClass(name="org.springframework.security.core.context.SecurityContextHolder")
|
@ConditionalOnMissingClass(name = "org.springframework.security.core.context.SecurityContextHolder")
|
||||||
protected static class AnonymousUserIdSourceConfig extends SocialConfigurerAdapter {
|
protected static class AnonymousUserIdSourceConfig extends SocialConfigurerAdapter {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -131,7 +137,6 @@ public class SocialWebAutoConfiguration {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Configuration
|
@Configuration
|
||||||
|
@ -148,6 +153,18 @@ public class SocialWebAutoConfiguration {
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Configuration
|
||||||
|
@ConditionalOnClass(SpringTemplateEngine.class)
|
||||||
|
protected static class SpringSocialThymeleafConfig {
|
||||||
|
|
||||||
|
@Bean
|
||||||
|
@ConditionalOnMissingBean
|
||||||
|
public SpringSocialDialect springSocialDialect() {
|
||||||
|
return new SpringSocialDialect();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
private static class SecurityContextUserIdSource implements UserIdSource {
|
private static class SecurityContextUserIdSource implements UserIdSource {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
import org.springframework.boot.autoconfigure.AutoConfigureAfter;
|
||||||
|
import org.springframework.boot.autoconfigure.AutoConfigureBefore;
|
||||||
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnClass;
|
||||||
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
import org.springframework.boot.autoconfigure.condition.ConditionalOnMissingBean;
|
||||||
|
@ -29,6 +30,7 @@ import org.springframework.context.annotation.Configuration;
|
||||||
import org.springframework.context.annotation.Scope;
|
import org.springframework.context.annotation.Scope;
|
||||||
import org.springframework.context.annotation.ScopedProxyMode;
|
import org.springframework.context.annotation.ScopedProxyMode;
|
||||||
import org.springframework.social.config.annotation.EnableSocial;
|
import org.springframework.social.config.annotation.EnableSocial;
|
||||||
|
import org.springframework.social.config.annotation.SocialConfigurerAdapter;
|
||||||
import org.springframework.social.connect.Connection;
|
import org.springframework.social.connect.Connection;
|
||||||
import org.springframework.social.connect.ConnectionFactory;
|
import org.springframework.social.connect.ConnectionFactory;
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
import org.springframework.social.connect.ConnectionRepository;
|
||||||
|
@ -46,7 +48,9 @@ import org.springframework.web.servlet.View;
|
||||||
* @since 1.1.0
|
* @since 1.1.0
|
||||||
*/
|
*/
|
||||||
@Configuration
|
@Configuration
|
||||||
@ConditionalOnClass({ TwitterConnectionFactory.class })
|
@ConditionalOnClass({ SocialConfigurerAdapter.class, TwitterConnectionFactory.class })
|
||||||
|
@ConditionalOnProperty(prefix = "spring.social.twitter.", value = "app-id")
|
||||||
|
@AutoConfigureBefore(SocialWebAutoConfiguration.class)
|
||||||
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
@AutoConfigureAfter(WebMvcAutoConfiguration.class)
|
||||||
public class TwitterAutoConfiguration {
|
public class TwitterAutoConfiguration {
|
||||||
|
|
||||||
|
@ -69,7 +73,7 @@ public class TwitterAutoConfiguration {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Bean
|
@Bean
|
||||||
@ConditionalOnMissingBean(TwitterConnectionFactory.class)
|
@ConditionalOnMissingBean
|
||||||
@Scope(value = "request", proxyMode = ScopedProxyMode.INTERFACES)
|
@Scope(value = "request", proxyMode = ScopedProxyMode.INTERFACES)
|
||||||
public Twitter twitter(ConnectionRepository repository) {
|
public Twitter twitter(ConnectionRepository repository) {
|
||||||
Connection<Twitter> connection = repository
|
Connection<Twitter> connection = repository
|
||||||
|
|
|
@ -0,0 +1,73 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2014 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.boot.autoconfigure.social;
|
||||||
|
|
||||||
|
import org.junit.After;
|
||||||
|
import org.springframework.beans.factory.NoSuchBeanDefinitionException;
|
||||||
|
import org.springframework.social.UserIdSource;
|
||||||
|
import org.springframework.social.connect.ConnectionFactoryLocator;
|
||||||
|
import org.springframework.social.connect.ConnectionRepository;
|
||||||
|
import org.springframework.social.connect.UsersConnectionRepository;
|
||||||
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
import static org.junit.Assert.fail;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Abstract base class for testing Spring Social auto-configuration.
|
||||||
|
*
|
||||||
|
* @author Craig Walls
|
||||||
|
*/
|
||||||
|
public class AbstractSocialAutoConfigurationTests {
|
||||||
|
|
||||||
|
protected AnnotationConfigWebApplicationContext context;
|
||||||
|
|
||||||
|
@After
|
||||||
|
public void close() {
|
||||||
|
if (this.context != null) {
|
||||||
|
this.context.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public AbstractSocialAutoConfigurationTests() {
|
||||||
|
super();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void assertConnectionFrameworkBeans() {
|
||||||
|
assertNotNull(this.context.getBean(UsersConnectionRepository.class));
|
||||||
|
assertNotNull(this.context.getBean(ConnectionRepository.class));
|
||||||
|
assertNotNull(this.context.getBean(ConnectionFactoryLocator.class));
|
||||||
|
assertNotNull(this.context.getBean(UserIdSource.class));
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void assertNoConnectionFrameworkBeans() {
|
||||||
|
assertMissingBean(UsersConnectionRepository.class);
|
||||||
|
assertMissingBean(ConnectionRepository.class);
|
||||||
|
assertMissingBean(ConnectionFactoryLocator.class);
|
||||||
|
assertMissingBean(UserIdSource.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected void assertMissingBean(Class<?> beanClass) {
|
||||||
|
try {
|
||||||
|
assertNotNull(this.context.getBean(beanClass));
|
||||||
|
fail("Unexpected bean in context of type " + beanClass.getName());
|
||||||
|
}
|
||||||
|
catch (NoSuchBeanDefinitionException ex) {
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -16,13 +16,8 @@
|
||||||
|
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.springframework.boot.test.EnvironmentTestUtils;
|
import org.springframework.boot.test.EnvironmentTestUtils;
|
||||||
import org.springframework.social.UserIdSource;
|
|
||||||
import org.springframework.social.connect.ConnectionFactoryLocator;
|
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
|
||||||
import org.springframework.social.connect.UsersConnectionRepository;
|
|
||||||
import org.springframework.social.facebook.api.Facebook;
|
import org.springframework.social.facebook.api.Facebook;
|
||||||
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
|
@ -33,16 +28,7 @@ import static org.junit.Assert.assertNotNull;
|
||||||
*
|
*
|
||||||
* @author Craig Walls
|
* @author Craig Walls
|
||||||
*/
|
*/
|
||||||
public class FacebookAutoConfigurationTests {
|
public class FacebookAutoConfigurationTests extends AbstractSocialAutoConfigurationTests {
|
||||||
|
|
||||||
private AnnotationConfigWebApplicationContext context;
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void close() {
|
|
||||||
if (this.context != null) {
|
|
||||||
this.context.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void expectedSocialBeansCreated() throws Exception {
|
public void expectedSocialBeansCreated() throws Exception {
|
||||||
|
@ -51,14 +37,20 @@ public class FacebookAutoConfigurationTests {
|
||||||
"spring.social.facebook.appId:12345");
|
"spring.social.facebook.appId:12345");
|
||||||
EnvironmentTestUtils.addEnvironment(this.context,
|
EnvironmentTestUtils.addEnvironment(this.context,
|
||||||
"spring.social.facebook.appSecret:secret");
|
"spring.social.facebook.appSecret:secret");
|
||||||
this.context.register(SocialWebAutoConfiguration.class);
|
|
||||||
this.context.register(FacebookAutoConfiguration.class);
|
this.context.register(FacebookAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
this.context.refresh();
|
this.context.refresh();
|
||||||
assertNotNull(this.context.getBean(UsersConnectionRepository.class));
|
assertConnectionFrameworkBeans();
|
||||||
assertNotNull(this.context.getBean(ConnectionRepository.class));
|
|
||||||
assertNotNull(this.context.getBean(ConnectionFactoryLocator.class));
|
|
||||||
assertNotNull(this.context.getBean(UserIdSource.class));
|
|
||||||
assertNotNull(this.context.getBean(Facebook.class));
|
assertNotNull(this.context.getBean(Facebook.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void noFacebookBeanCreatedWhenPropertiesArentSet() throws Exception {
|
||||||
|
this.context = new AnnotationConfigWebApplicationContext();
|
||||||
|
this.context.register(FacebookAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
|
this.context.refresh();
|
||||||
|
assertNoConnectionFrameworkBeans();
|
||||||
|
assertMissingBean(Facebook.class);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,13 +16,8 @@
|
||||||
|
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.springframework.boot.test.EnvironmentTestUtils;
|
import org.springframework.boot.test.EnvironmentTestUtils;
|
||||||
import org.springframework.social.UserIdSource;
|
|
||||||
import org.springframework.social.connect.ConnectionFactoryLocator;
|
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
|
||||||
import org.springframework.social.connect.UsersConnectionRepository;
|
|
||||||
import org.springframework.social.linkedin.api.LinkedIn;
|
import org.springframework.social.linkedin.api.LinkedIn;
|
||||||
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
|
@ -33,16 +28,7 @@ import static org.junit.Assert.assertNotNull;
|
||||||
*
|
*
|
||||||
* @author Craig Walls
|
* @author Craig Walls
|
||||||
*/
|
*/
|
||||||
public class LinkedInAutoConfigurationTests {
|
public class LinkedInAutoConfigurationTests extends AbstractSocialAutoConfigurationTests {
|
||||||
|
|
||||||
private AnnotationConfigWebApplicationContext context;
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void close() {
|
|
||||||
if (this.context != null) {
|
|
||||||
this.context.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void expectedSocialBeansCreated() throws Exception {
|
public void expectedSocialBeansCreated() throws Exception {
|
||||||
|
@ -51,14 +37,21 @@ public class LinkedInAutoConfigurationTests {
|
||||||
"spring.social.linkedin.appId:12345");
|
"spring.social.linkedin.appId:12345");
|
||||||
EnvironmentTestUtils.addEnvironment(this.context,
|
EnvironmentTestUtils.addEnvironment(this.context,
|
||||||
"spring.social.linkedin.appSecret:secret");
|
"spring.social.linkedin.appSecret:secret");
|
||||||
this.context.register(SocialWebAutoConfiguration.class);
|
|
||||||
this.context.register(LinkedInAutoConfiguration.class);
|
this.context.register(LinkedInAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
this.context.refresh();
|
this.context.refresh();
|
||||||
assertNotNull(this.context.getBean(UsersConnectionRepository.class));
|
assertConnectionFrameworkBeans();
|
||||||
assertNotNull(this.context.getBean(ConnectionRepository.class));
|
|
||||||
assertNotNull(this.context.getBean(ConnectionFactoryLocator.class));
|
|
||||||
assertNotNull(this.context.getBean(UserIdSource.class));
|
|
||||||
assertNotNull(this.context.getBean(LinkedIn.class));
|
assertNotNull(this.context.getBean(LinkedIn.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void noLinkedInBeanCreatedIfPropertiesArentSet() throws Exception {
|
||||||
|
this.context = new AnnotationConfigWebApplicationContext();
|
||||||
|
this.context.register(LinkedInAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
|
this.context.refresh();
|
||||||
|
assertNoConnectionFrameworkBeans();
|
||||||
|
assertMissingBean(LinkedIn.class);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,120 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2012-2014 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.boot.autoconfigure.social;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.springframework.boot.test.EnvironmentTestUtils;
|
||||||
|
import org.springframework.social.facebook.api.Facebook;
|
||||||
|
import org.springframework.social.linkedin.api.LinkedIn;
|
||||||
|
import org.springframework.social.twitter.api.Twitter;
|
||||||
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
|
import static org.junit.Assert.assertNotNull;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests for Spring Social configuration with multiple API providers.
|
||||||
|
*
|
||||||
|
* @author Craig Walls
|
||||||
|
*/
|
||||||
|
public class MultiApiAutoConfigurationTests extends AbstractSocialAutoConfigurationTests {
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectTwitterConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.twitter.appId:12345",
|
||||||
|
"spring.social.twitter.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(Twitter.class));
|
||||||
|
assertMissingBean(Facebook.class);
|
||||||
|
assertMissingBean(LinkedIn.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectFacebookConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.facebook.appId:12345",
|
||||||
|
"spring.social.facebook.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(Facebook.class));
|
||||||
|
assertMissingBean(Twitter.class);
|
||||||
|
assertMissingBean(LinkedIn.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectLinkedInConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.linkedin.appId:12345",
|
||||||
|
"spring.social.linkedin.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(LinkedIn.class));
|
||||||
|
assertMissingBean(Twitter.class);
|
||||||
|
assertMissingBean(Facebook.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectFacebookAndLinkedInConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.facebook.appId:54321",
|
||||||
|
"spring.social.facebook.appSecret:shhhhh",
|
||||||
|
"spring.social.linkedin.appId:12345",
|
||||||
|
"spring.social.linkedin.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(Facebook.class));
|
||||||
|
assertNotNull(this.context.getBean(LinkedIn.class));
|
||||||
|
assertMissingBean(Twitter.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectFacebookAndTwitterConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.facebook.appId:54321",
|
||||||
|
"spring.social.facebook.appSecret:shhhhh",
|
||||||
|
"spring.social.twitter.appId:12345",
|
||||||
|
"spring.social.twitter.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(Facebook.class));
|
||||||
|
assertNotNull(this.context.getBean(Twitter.class));
|
||||||
|
assertMissingBean(LinkedIn.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void expectLinkedInAndTwitterConfigurationOnly() throws Exception {
|
||||||
|
setupContext("spring.social.linkedin.appId:54321",
|
||||||
|
"spring.social.linkedin.appSecret:shhhhh",
|
||||||
|
"spring.social.twitter.appId:12345",
|
||||||
|
"spring.social.twitter.appSecret:secret");
|
||||||
|
assertConnectionFrameworkBeans();
|
||||||
|
assertNotNull(this.context.getBean(LinkedIn.class));
|
||||||
|
assertNotNull(this.context.getBean(Twitter.class));
|
||||||
|
assertMissingBean(Facebook.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void noSocialBeansCreatedWhenPropertiesArentSet() throws Exception {
|
||||||
|
setupContext();
|
||||||
|
assertNoConnectionFrameworkBeans();
|
||||||
|
assertMissingBean(Twitter.class);
|
||||||
|
assertMissingBean(Facebook.class);
|
||||||
|
assertMissingBean(LinkedIn.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setupContext(String... environment) {
|
||||||
|
this.context = new AnnotationConfigWebApplicationContext();
|
||||||
|
EnvironmentTestUtils.addEnvironment(this.context, environment);
|
||||||
|
this.context.register(TwitterAutoConfiguration.class);
|
||||||
|
this.context.register(FacebookAutoConfiguration.class);
|
||||||
|
this.context.register(LinkedInAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
|
this.context.refresh();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -16,13 +16,8 @@
|
||||||
|
|
||||||
package org.springframework.boot.autoconfigure.social;
|
package org.springframework.boot.autoconfigure.social;
|
||||||
|
|
||||||
import org.junit.After;
|
|
||||||
import org.junit.Test;
|
import org.junit.Test;
|
||||||
import org.springframework.boot.test.EnvironmentTestUtils;
|
import org.springframework.boot.test.EnvironmentTestUtils;
|
||||||
import org.springframework.social.UserIdSource;
|
|
||||||
import org.springframework.social.connect.ConnectionFactoryLocator;
|
|
||||||
import org.springframework.social.connect.ConnectionRepository;
|
|
||||||
import org.springframework.social.connect.UsersConnectionRepository;
|
|
||||||
import org.springframework.social.twitter.api.Twitter;
|
import org.springframework.social.twitter.api.Twitter;
|
||||||
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
import org.springframework.web.context.support.AnnotationConfigWebApplicationContext;
|
||||||
|
|
||||||
|
@ -33,16 +28,7 @@ import static org.junit.Assert.assertNotNull;
|
||||||
*
|
*
|
||||||
* @author Craig Walls
|
* @author Craig Walls
|
||||||
*/
|
*/
|
||||||
public class TwitterAutoConfigurationTests {
|
public class TwitterAutoConfigurationTests extends AbstractSocialAutoConfigurationTests {
|
||||||
|
|
||||||
private AnnotationConfigWebApplicationContext context;
|
|
||||||
|
|
||||||
@After
|
|
||||||
public void close() {
|
|
||||||
if (this.context != null) {
|
|
||||||
this.context.close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void expectedSocialBeansCreated() throws Exception {
|
public void expectedSocialBeansCreated() throws Exception {
|
||||||
|
@ -51,14 +37,21 @@ public class TwitterAutoConfigurationTests {
|
||||||
"spring.social.twitter.appId:12345");
|
"spring.social.twitter.appId:12345");
|
||||||
EnvironmentTestUtils.addEnvironment(this.context,
|
EnvironmentTestUtils.addEnvironment(this.context,
|
||||||
"spring.social.twitter.appSecret:secret");
|
"spring.social.twitter.appSecret:secret");
|
||||||
this.context.register(SocialWebAutoConfiguration.class);
|
|
||||||
this.context.register(TwitterAutoConfiguration.class);
|
this.context.register(TwitterAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
this.context.refresh();
|
this.context.refresh();
|
||||||
assertNotNull(this.context.getBean(UsersConnectionRepository.class));
|
assertConnectionFrameworkBeans();
|
||||||
assertNotNull(this.context.getBean(ConnectionRepository.class));
|
|
||||||
assertNotNull(this.context.getBean(ConnectionFactoryLocator.class));
|
|
||||||
assertNotNull(this.context.getBean(UserIdSource.class));
|
|
||||||
assertNotNull(this.context.getBean(Twitter.class));
|
assertNotNull(this.context.getBean(Twitter.class));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void noTwitterBeanCreatedWhenPropertiesArentSet() throws Exception {
|
||||||
|
this.context = new AnnotationConfigWebApplicationContext();
|
||||||
|
this.context.register(TwitterAutoConfiguration.class);
|
||||||
|
this.context.register(SocialWebAutoConfiguration.class);
|
||||||
|
this.context.refresh();
|
||||||
|
assertNoConnectionFrameworkBeans();
|
||||||
|
assertMissingBean(Twitter.class);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue