【发布时间】:2020-07-13 12:08:47
【问题描述】:
我创建了一个 Bearer 令牌创建器,当我编写它的测试时,测试总是失败并返回 nullPointerException 有什么问题?
注意:不记名令牌语法类似于 [Bearer {someEncodedCharacter}]。
import java.io.IOException;
import javax.servlet.FilterChain;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.junit.Test;
import org.mockito.Mockito;
import org.springframework.boot.test.autoconfigure.web.servlet.WebMvcTest;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.boot.test.mock.mockito.MockBean;
import org.springframework.security.core.Authentication;
import org.springframework.security.core.context.SecurityContext;
import org.springframework.security.core.context.SecurityContextHolder;
@SpringBootTest
public class JwtTokenFilterTest {
@MockBean
private HttpServletRequest httpRequest;
@MockBean
private TokenManager tokenManagerTester;
@MockBean
private Authentication authentication;
@MockBean
private SecurityContext securityContext;
@MockBean
private HttpServletResponse httpResponse;
@MockBean
private FilterChain filterChain;
@Test
public void givenHttpServletRequestandHttpServletResponseandFilterChainDoFilterInternal()
throws ServletException, IOException {
String token="eyJhbGciOiJIUzI1NiJ9.eyJzdWIiOiJhYmMxMjMiLCJpc3MiOiJ3d3cuYWJjLmNvbSIsImlhdCI6MTU5NDY0MTUzNywiZXhwIjoxNTk0NjQxODM3fQ.GHzVaQW_tvqo8HlDmoXzZ8WIYGcLHciLOSMFxsZUOsY";
Mockito.when(httpRequest.getHeader("Authorization")).thenReturn("Bearer "+token);
Mockito.when(securityContext.getAuthentication()).thenReturn(authentication);
SecurityContextHolder.setContext(securityContext);
Mockito.when(tokenManagerTester.tokenValidate(Mockito.anyString())).thenReturn(true);
Mockito.when(tokenManagerTester
.getUsernameToken(token))
.thenReturn("abc123");
JwtTokenFilter filter=new JwtTokenFilter();
filter.doFilterInternal(httpRequest, httpResponse, filterChain);
Mockito.verify(filterChain,Mockito.times(1));
}
}
这里是 JwtfFilter:
@Component
public class JwtTokenFilter extends OncePerRequestFilter {
@Autowired
private TokenManager tokenManager;
@Override
protected void doFilterInternal(HttpServletRequest httpServletRequest,
@NotNull HttpServletResponse httpServletResponse,
@NotNull FilterChain filterChain) throws ServletException, IOException {
/**
* We are parsing our token in two pieces and we process the second
* "Bearer hvs231asas2355"
*/
final String authHeader = httpServletRequest.getHeader("Authorization");
/* */
String username = null;
String token = null;
if (authHeader != null && authHeader.contains("Bearer")) {
token = authHeader.substring(7);
try {
username = tokenManager.getUsernameToken(token);
} catch (Exception e) {
System.out.println(e.getMessage());
}
}
if (username != null && SecurityContextHolder.getContext().getAuthentication() == null) {
if (tokenManager.tokenValidate(token)) {
UsernamePasswordAuthenticationToken upassToken =
new UsernamePasswordAuthenticationToken(username, null, new ArrayList<>());
upassToken.setDetails(new WebAuthenticationDetailsSource().buildDetails(httpServletRequest));
SecurityContextHolder.getContext().setAuthentication(upassToken);
}
}
filterChain.doFilter(httpServletRequest, httpServletResponse);
}
}
注 2:我认为如果我控制 filterChain.dofilter 我可以看到该方法工作正常。出于这个原因,我写了 Mockito.verify(filterChain,Mockito.times(1));
【问题讨论】:
标签: java spring spring-boot testing spring-security