Updated Third Party Issuer Service unit tests.
parent
8c8aeeb892
commit
0e777917d3
|
@ -28,6 +28,8 @@ import org.mitre.openid.connect.client.model.IssuerServiceResponse;
|
||||||
import org.mockito.Mockito;
|
import org.mockito.Mockito;
|
||||||
import org.springframework.security.authentication.AuthenticationServiceException;
|
import org.springframework.security.authentication.AuthenticationServiceException;
|
||||||
|
|
||||||
|
import com.google.common.collect.Sets;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @author wkim
|
* @author wkim
|
||||||
*
|
*
|
||||||
|
@ -36,62 +38,91 @@ public class TestThirdPartyIssuerService {
|
||||||
|
|
||||||
// Test fixture:
|
// Test fixture:
|
||||||
private HttpServletRequest request;
|
private HttpServletRequest request;
|
||||||
|
|
||||||
private String iss = "https://server.example.org";
|
private String iss = "https://server.example.org";
|
||||||
private String login_hint = "I'm not telling you nothin!";
|
private String login_hint = "I'm not telling you nothin!";
|
||||||
private String target_link_uri = "https://www.example.com";
|
private String target_link_uri = "https://www.example.com";
|
||||||
private String redirect_uri = "https://www.example.com";
|
private String redirect_uri = "https://www.example.com";
|
||||||
|
|
||||||
private String accountChooserUrl = "https://www.example.com/account";
|
private String accountChooserUrl = "https://www.example.com/account";
|
||||||
|
|
||||||
private ThirdPartyIssuerService service = new ThirdPartyIssuerService();
|
private ThirdPartyIssuerService service = new ThirdPartyIssuerService();
|
||||||
|
|
||||||
@Before
|
@Before
|
||||||
public void prepare() {
|
public void prepare() {
|
||||||
|
|
||||||
service.setAccountChooserUrl(accountChooserUrl);
|
service.setAccountChooserUrl(accountChooserUrl);
|
||||||
|
|
||||||
request = Mockito.mock(HttpServletRequest.class);
|
request = Mockito.mock(HttpServletRequest.class);
|
||||||
Mockito.when(request.getParameter("iss")).thenReturn(iss);
|
Mockito.when(request.getParameter("iss")).thenReturn(iss);
|
||||||
Mockito.when(request.getParameter("login_hint")).thenReturn(login_hint);
|
Mockito.when(request.getParameter("login_hint")).thenReturn(login_hint);
|
||||||
Mockito.when(request.getParameter("target_link_uri")).thenReturn(target_link_uri);
|
Mockito.when(request.getParameter("target_link_uri")).thenReturn(target_link_uri);
|
||||||
Mockito.when(request.getRequestURL()).thenReturn(new StringBuffer(redirect_uri));
|
Mockito.when(request.getRequestURL()).thenReturn(new StringBuffer(redirect_uri));
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getIssuer_hasIssuer() {
|
public void getIssuer_hasIssuer() {
|
||||||
|
|
||||||
IssuerServiceResponse response = service.getIssuer(request);
|
IssuerServiceResponse response = service.getIssuer(request);
|
||||||
|
|
||||||
assertThat(response.getIssuer(), equalTo(iss));
|
assertThat(response.getIssuer(), equalTo(iss));
|
||||||
assertThat(response.getLoginHint(), equalTo(login_hint));
|
assertThat(response.getLoginHint(), equalTo(login_hint));
|
||||||
assertThat(response.getTargetLinkUri(), equalTo(target_link_uri));
|
assertThat(response.getTargetLinkUri(), equalTo(target_link_uri));
|
||||||
|
|
||||||
assertThat(response.getRedirectUrl(), nullValue());
|
assertThat(response.getRedirectUrl(), nullValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
@Test
|
@Test
|
||||||
public void getIssuer_noIssuer() {
|
public void getIssuer_noIssuer() {
|
||||||
|
|
||||||
Mockito.when(request.getParameter("iss")).thenReturn(null);
|
Mockito.when(request.getParameter("iss")).thenReturn(null);
|
||||||
|
|
||||||
IssuerServiceResponse response = service.getIssuer(request);
|
IssuerServiceResponse response = service.getIssuer(request);
|
||||||
|
|
||||||
assertThat(response.getIssuer(), nullValue());
|
assertThat(response.getIssuer(), nullValue());
|
||||||
assertThat(response.getLoginHint(), nullValue());
|
assertThat(response.getLoginHint(), nullValue());
|
||||||
assertThat(response.getTargetLinkUri(), nullValue());
|
assertThat(response.getTargetLinkUri(), nullValue());
|
||||||
|
|
||||||
String expectedRedirectUrl = accountChooserUrl + "?redirect_uri=" +
|
String expectedRedirectUrl = accountChooserUrl + "?redirect_uri=" + "https%3A%2F%2Fwww.example.com"; // url-encoded string of the request url
|
||||||
"https%3A%2F%2Fwww.example.com"; // url-encoded string of the request url
|
|
||||||
assertThat(response.getRedirectUrl(), equalTo(expectedRedirectUrl));
|
assertThat(response.getRedirectUrl(), equalTo(expectedRedirectUrl));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void getIssuer_isWhitelisted() {
|
||||||
|
|
||||||
|
service.setWhitelist(Sets.newHashSet(iss));
|
||||||
|
|
||||||
|
IssuerServiceResponse response = service.getIssuer(request);
|
||||||
|
|
||||||
|
assertThat(response.getIssuer(), equalTo(iss));
|
||||||
|
assertThat(response.getLoginHint(), equalTo(login_hint));
|
||||||
|
assertThat(response.getTargetLinkUri(), equalTo(target_link_uri));
|
||||||
|
|
||||||
|
assertThat(response.getRedirectUrl(), nullValue());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = AuthenticationServiceException.class)
|
||||||
|
public void getIssuer_notWhitelisted() {
|
||||||
|
|
||||||
|
service.setWhitelist(Sets.newHashSet("some.other.site"));
|
||||||
|
|
||||||
|
service.getIssuer(request);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test(expected = AuthenticationServiceException.class)
|
||||||
|
public void getIssuer_blacklisted() {
|
||||||
|
|
||||||
|
service.setBlacklist(Sets.newHashSet(iss));
|
||||||
|
|
||||||
|
service.getIssuer(request);
|
||||||
|
}
|
||||||
|
|
||||||
@Test(expected = AuthenticationServiceException.class)
|
@Test(expected = AuthenticationServiceException.class)
|
||||||
public void getIssuer_badUri() {
|
public void getIssuer_badUri() {
|
||||||
|
|
||||||
Mockito.when(request.getParameter("iss")).thenReturn(null);
|
Mockito.when(request.getParameter("iss")).thenReturn(null);
|
||||||
service.setAccountChooserUrl("e=mc^2");
|
service.setAccountChooserUrl("e=mc^2");
|
||||||
|
|
||||||
service.getIssuer(request);
|
service.getIssuer(request);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue