/* * Copyright 2002-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.security.test.context.support; import static org.assertj.core.api.Assertions.assertThat; import static org.mockito.Mockito.*; import org.junit.Before; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.Mock; import org.mockito.runners.MockitoJUnitRunner; import org.springframework.beans.factory.BeanFactory; import org.springframework.security.authentication.UsernamePasswordAuthenticationToken; import org.springframework.security.core.context.SecurityContext; import org.springframework.security.core.userdetails.UserDetails; import org.springframework.security.core.userdetails.UserDetailsService; @RunWith(MockitoJUnitRunner.class) public class WithUserDetailsSecurityContextFactoryTests { @Mock private UserDetailsService userDetailsService; @Mock private UserDetails userDetails; @Mock private BeanFactory beans; @Mock private WithUserDetails withUserDetails; private WithUserDetailsSecurityContextFactory factory; @Before public void setup() { when(beans.getBean(UserDetailsService.class)).thenReturn(userDetailsService); factory = new WithUserDetailsSecurityContextFactory(beans); } @Test(expected = IllegalArgumentException.class) public void createSecurityContextNullValue() { factory.createSecurityContext(withUserDetails); } @Test(expected = IllegalArgumentException.class) public void createSecurityContextEmptyValue() { when(withUserDetails.value()).thenReturn(""); factory.createSecurityContext(withUserDetails); } @Test public void createSecurityContextWithExistingUser() { String username = "user"; when(withUserDetails.value()).thenReturn(username); when(userDetailsService.loadUserByUsername(username)).thenReturn(userDetails); SecurityContext context = factory.createSecurityContext(withUserDetails); assertThat(context.getAuthentication()).isInstanceOf( UsernamePasswordAuthenticationToken.class); assertThat(context.getAuthentication().getPrincipal()).isEqualTo(userDetails); verify(beans).getBean(UserDetailsService.class); verifyNoMoreInteractions(beans); } // gh-3346 @Test public void createSecurityContextWithUserDetailsServiceName() { String beanName = "secondUserDetailsServiceBean"; String username = "user"; when(withUserDetails.value()).thenReturn(username); when(withUserDetails.userDetailsServiceBeanName()).thenReturn(beanName); when(userDetailsService.loadUserByUsername(username)).thenReturn(userDetails); when(beans.getBean(beanName, UserDetailsService.class)).thenReturn(userDetailsService); SecurityContext context = factory.createSecurityContext(withUserDetails); assertThat(context.getAuthentication()).isInstanceOf( UsernamePasswordAuthenticationToken.class); assertThat(context.getAuthentication().getPrincipal()).isEqualTo(userDetails); verify(beans).getBean(beanName, UserDetailsService.class); verifyNoMoreInteractions(beans); } }