Я создал создателя токена на предъявителя, и когда я пишу его тест, тест всегда терпит неудачу и возвращает 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));