Updated Third Party Issuer Service unit tests.

pull/477/head
William Kim 2013-07-02 09:40:17 -04:00
parent 8c8aeeb892
commit 0e777917d3
1 changed files with 51 additions and 20 deletions

View File

@ -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);
} }
} }