Merge pull request #1791 from vramik/uitests
arquillian-testsuite add UI tests, page objects refactoring
This commit is contained in:
commit
5a318df041
9 changed files with 502 additions and 231 deletions
|
@ -3,6 +3,7 @@ package org.keycloak.testsuite.console.page.authentication;
|
|||
import org.keycloak.testsuite.console.page.AdminConsoleRealm;
|
||||
import org.openqa.selenium.WebElement;
|
||||
import org.openqa.selenium.support.FindBy;
|
||||
import static org.keycloak.testsuite.util.WaitUtils.waitAjaxForElement;
|
||||
|
||||
/**
|
||||
* @author tkyjovsk
|
||||
|
@ -13,6 +14,22 @@ public class Authentication extends AdminConsoleRealm {
|
|||
@FindBy(xpath = "//h1[text()='Authentication']/..")
|
||||
private AuthenticationTabs authenticationTabs;
|
||||
|
||||
@FindBy(xpath = "//div[contains(@class, 'alert-danger')]")
|
||||
private WebElement error;
|
||||
|
||||
@FindBy(xpath = "//div[contains(@class, 'alert-success')]")
|
||||
private WebElement success;
|
||||
|
||||
public String getSuccessMessage() {
|
||||
waitAjaxForElement(success);
|
||||
return success.getText();
|
||||
}
|
||||
|
||||
public String getErrorMessage() {
|
||||
waitAjaxForElement(error);
|
||||
return error.getText();
|
||||
}
|
||||
|
||||
public AuthenticationTabs tabs() {
|
||||
return authenticationTabs;
|
||||
}
|
||||
|
|
|
@ -1,146 +0,0 @@
|
|||
package org.keycloak.testsuite.console.page.authentication;
|
||||
|
||||
import org.openqa.selenium.WebElement;
|
||||
import org.openqa.selenium.support.FindBy;
|
||||
import org.openqa.selenium.support.ui.Select;
|
||||
|
||||
/**
|
||||
* Created by mhajas on 8/21/15.
|
||||
*/
|
||||
public class Bindings extends Authentication {
|
||||
|
||||
@Override
|
||||
public String getUriFragment() {
|
||||
return super.getUriFragment() + "/flow-binding";
|
||||
}
|
||||
|
||||
@FindBy(id = "browser")
|
||||
private Select BrowserFlowSelect;
|
||||
|
||||
@FindBy(id = "registration")
|
||||
private Select RegistrationFlowSelect;
|
||||
|
||||
@FindBy(id = "grant")
|
||||
private Select DirectGrantFlowSelect;
|
||||
|
||||
@FindBy(id = "resetCredentials")
|
||||
private Select ResetCredentialsSelect;
|
||||
|
||||
@FindBy(id = "clientAuthentication")
|
||||
private Select ClientAuthenticationSelect;
|
||||
|
||||
@FindBy(xpath = "//button[text()='Save']")
|
||||
private WebElement saveButton;
|
||||
|
||||
@FindBy(xpath = "//button[text()='Cancel']")
|
||||
private WebElement cancelButton;
|
||||
|
||||
public void changeBrowserFlowSelect(BrowserFlowSelectValues value) {
|
||||
BrowserFlowSelect.selectByVisibleText(value.getName());
|
||||
}
|
||||
|
||||
public void changeRegistrationFlowSelect(RegistrationFlowSelectValues value) {
|
||||
RegistrationFlowSelect.selectByVisibleText(value.getName());
|
||||
}
|
||||
|
||||
public void changeDirectGrantFlowSelect(DirectGrantFlowSelectValues value) {
|
||||
DirectGrantFlowSelect.selectByVisibleText(value.getName());
|
||||
}
|
||||
|
||||
public void changeResetCredentialsSelect(ResetCredentialsSelectValues value) {
|
||||
ResetCredentialsSelect.selectByVisibleText(value.getName());
|
||||
}
|
||||
|
||||
public void changeClientAuthenticationSelect(ClientAuthenticationSelectValues value) {
|
||||
ClientAuthenticationSelect.selectByVisibleText(value.getName());
|
||||
}
|
||||
|
||||
public void clickSave() {
|
||||
saveButton.click();
|
||||
}
|
||||
|
||||
public void clickCancel() {
|
||||
cancelButton.click();
|
||||
}
|
||||
|
||||
public enum BrowserFlowSelectValues {
|
||||
|
||||
DIRECT_GRANT("direct grant"), REGISTRATION("registration"), BROWSER("browser"),
|
||||
RESET_CREDENTIALS("reset credentials");
|
||||
|
||||
private String name;
|
||||
|
||||
private BrowserFlowSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum RegistrationFlowSelectValues {
|
||||
|
||||
DIRECT_GRANT("direct grant"), REGISTRATION("registration"), BROWSER("browser"),
|
||||
RESET_CREDENTIALS("reset credentials");
|
||||
|
||||
private String name;
|
||||
|
||||
private RegistrationFlowSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum DirectGrantFlowSelectValues {
|
||||
|
||||
DIRECT_GRANT("direct grant"), REGISTRATION("registration"), BROWSER("browser"),
|
||||
RESET_CREDENTIALS("reset credentials");
|
||||
|
||||
private String name;
|
||||
|
||||
private DirectGrantFlowSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum ResetCredentialsSelectValues {
|
||||
|
||||
DIRECT_GRANT("direct grant"), REGISTRATION("registration"), BROWSER("browser"),
|
||||
RESET_CREDENTIALS("reset credentials"), NOTHING("");
|
||||
|
||||
private String name;
|
||||
|
||||
private ResetCredentialsSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum ClientAuthenticationSelectValues {
|
||||
|
||||
CLIENTS("clients");
|
||||
|
||||
private String name;
|
||||
|
||||
private ClientAuthenticationSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
}
|
|
@ -1,85 +0,0 @@
|
|||
package org.keycloak.testsuite.console.page.authentication;
|
||||
|
||||
import org.keycloak.testsuite.page.Form;
|
||||
import org.openqa.selenium.WebElement;
|
||||
import org.openqa.selenium.support.FindBy;
|
||||
|
||||
/**
|
||||
* Created by mhajas on 8/21/15.
|
||||
*/
|
||||
public class OTPPolicy extends Authentication {
|
||||
|
||||
@FindBy(linkText = "Save")
|
||||
private WebElement saveButton;
|
||||
|
||||
public void clickSave() {
|
||||
saveButton.click();
|
||||
}
|
||||
|
||||
@FindBy(linkText = "Cancel")
|
||||
private WebElement cancelButton;
|
||||
|
||||
@FindBy(id = "lookAhead")
|
||||
private WebElement lookAheadInput;
|
||||
|
||||
@FindBy(id = "counter")
|
||||
private WebElement initialCounterInput;
|
||||
|
||||
public void clickCancel() {
|
||||
cancelButton.click();
|
||||
}
|
||||
|
||||
public void setLookAheadInputValue(String value) {
|
||||
Form.setInputValue(lookAheadInput, value);
|
||||
}
|
||||
|
||||
public void setInitialcounterInputValue(String value) {
|
||||
Form.setInputValue(initialCounterInput, value);
|
||||
}
|
||||
|
||||
public enum OTPTypeSelectValues {
|
||||
|
||||
TIME_BASED("time Based"), COUNTER_BASED("Counter Based");
|
||||
|
||||
private String name;
|
||||
|
||||
private OTPTypeSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum OTPHashAlgorithmSelectValues {
|
||||
|
||||
SHA1("SHA1"), SHA256("SHA256"), SHA512("SHA512");
|
||||
|
||||
private String name;
|
||||
|
||||
private OTPHashAlgorithmSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum NumberOfDigitsSelectValues {
|
||||
|
||||
NUMBER6("6"), NUMBER8("8");
|
||||
|
||||
private String name;
|
||||
|
||||
private NumberOfDigitsSelectValues(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
|
@ -0,0 +1,44 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.page.authentication.bindings;
|
||||
|
||||
import org.jboss.arquillian.graphene.page.Page;
|
||||
import org.keycloak.testsuite.console.page.authentication.Authentication;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class Bindings extends Authentication {
|
||||
|
||||
@Override
|
||||
public String getUriFragment() {
|
||||
return super.getUriFragment() + "/flow-bindings";
|
||||
}
|
||||
|
||||
@Page
|
||||
private BindingsForm form;
|
||||
|
||||
public BindingsForm form() {
|
||||
return form;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,95 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.page.authentication.bindings;
|
||||
|
||||
import org.keycloak.testsuite.console.page.authentication.bindings.BindingsForm.BindingsSelect;
|
||||
import org.keycloak.testsuite.page.Form;
|
||||
import org.openqa.selenium.support.FindBy;
|
||||
import org.openqa.selenium.support.ui.Select;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class BindingsForm extends Form {
|
||||
|
||||
@FindBy(id = "browser")
|
||||
private Select browser;
|
||||
|
||||
@FindBy(id = "registration")
|
||||
private Select registration;
|
||||
|
||||
@FindBy(id = "grant")
|
||||
private Select grant;
|
||||
|
||||
@FindBy(id = "resetCredentials")
|
||||
private Select resetCredentials;
|
||||
|
||||
@FindBy(id = "clientAuthentication")
|
||||
private Select clientAuthentication;
|
||||
|
||||
public void select(BindingsSelect select, BindingsOption option) {
|
||||
switch (select) {
|
||||
case BROWSER:
|
||||
browser.selectByVisibleText(option.getName());
|
||||
break;
|
||||
case REGISTRATION:
|
||||
registration.selectByVisibleText(option.getName());
|
||||
break;
|
||||
case DIRECT_GRANT:
|
||||
grant.selectByVisibleText(option.getName());
|
||||
break;
|
||||
case RESET_CREDENTIALS:
|
||||
resetCredentials.selectByVisibleText(option.getName());
|
||||
break;
|
||||
case CLIENT_AUTHENTICATION:
|
||||
clientAuthentication.selectByVisibleText(option.getName());
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
public enum BindingsSelect {
|
||||
BROWSER,
|
||||
REGISTRATION,
|
||||
DIRECT_GRANT,
|
||||
RESET_CREDENTIALS,
|
||||
CLIENT_AUTHENTICATION;
|
||||
}
|
||||
|
||||
public enum BindingsOption {
|
||||
|
||||
DIRECT_GRANT("direct grant"),
|
||||
REGISTRATION("registration"),
|
||||
BROWSER("browser"),
|
||||
RESET_CREDENTIALS("reset credentials");
|
||||
|
||||
private final String name;
|
||||
|
||||
private BindingsOption(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,44 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.page.authentication.otppolicy;
|
||||
|
||||
import org.jboss.arquillian.graphene.page.Page;
|
||||
import org.keycloak.testsuite.console.page.authentication.Authentication;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class OTPPolicy extends Authentication {
|
||||
|
||||
@Override
|
||||
public String getUriFragment() {
|
||||
return super.getUriFragment() + "/otp-policy";
|
||||
}
|
||||
|
||||
@Page
|
||||
private OTPPolicyForm form;
|
||||
|
||||
public OTPPolicyForm form() {
|
||||
return form;
|
||||
}
|
||||
}
|
|
@ -0,0 +1,119 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.page.authentication.otppolicy;
|
||||
|
||||
import org.keycloak.testsuite.page.Form;
|
||||
import org.openqa.selenium.WebElement;
|
||||
import org.openqa.selenium.support.FindBy;
|
||||
import org.openqa.selenium.support.ui.Select;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class OTPPolicyForm extends Form {
|
||||
|
||||
@FindBy(id = "type")
|
||||
private Select otpType;
|
||||
|
||||
@FindBy(id = "alg")
|
||||
private Select otpHashAlg;
|
||||
|
||||
@FindBy(id = "digits")
|
||||
private Select digits;
|
||||
|
||||
@FindBy(id = "lookAhead")
|
||||
private WebElement lookAhead;
|
||||
|
||||
@FindBy(id = "period")
|
||||
private WebElement period;
|
||||
|
||||
@FindBy(id = "counter")
|
||||
private WebElement counter;
|
||||
|
||||
public void setValues(OTPType otpType, OTPHashAlg otpHashAlg, Digits digits, String lookAhead, String periodOrCounter) {
|
||||
this.otpType.selectByValue(otpType.getName());
|
||||
this.otpHashAlg.selectByValue(otpHashAlg.getName());
|
||||
this.digits.selectByValue(digits.getName());
|
||||
setInputValue(this.lookAhead, lookAhead);
|
||||
|
||||
switch (otpType) {
|
||||
case TIME_BASED:
|
||||
setInputValue(period, periodOrCounter);
|
||||
break;
|
||||
case COUNTER_BASED:
|
||||
setInputValue(counter, periodOrCounter);
|
||||
break;
|
||||
}
|
||||
save();
|
||||
}
|
||||
|
||||
public enum OTPType {
|
||||
|
||||
TIME_BASED("totp"),
|
||||
COUNTER_BASED("hotp");
|
||||
|
||||
private final String name;
|
||||
|
||||
private OTPType(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum OTPHashAlg {
|
||||
|
||||
SHA1("HmacSHA1"),
|
||||
SHA256("HmacSHA256"),
|
||||
SHA512("HmacSHA512");
|
||||
|
||||
private final String name;
|
||||
|
||||
private OTPHashAlg(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
|
||||
public enum Digits {
|
||||
|
||||
EMPTY("? number:6 ?"),
|
||||
SIX("6"),
|
||||
EIGHT("8");
|
||||
|
||||
private final String name;
|
||||
|
||||
private Digits(String name) {
|
||||
this.name = name;
|
||||
}
|
||||
|
||||
public String getName() {
|
||||
return name;
|
||||
}
|
||||
}
|
||||
}
|
|
@ -0,0 +1,66 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.authentication;
|
||||
|
||||
import org.jboss.arquillian.graphene.page.Page;
|
||||
import static org.junit.Assert.assertEquals;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.keycloak.representations.idm.RealmRepresentation;
|
||||
import org.keycloak.testsuite.console.AbstractConsoleTest;
|
||||
import org.keycloak.testsuite.console.page.authentication.bindings.Bindings;
|
||||
import org.keycloak.testsuite.console.page.authentication.bindings.BindingsForm.BindingsOption;
|
||||
import org.keycloak.testsuite.console.page.authentication.bindings.BindingsForm.BindingsSelect;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class BindingsTest extends AbstractConsoleTest {
|
||||
|
||||
@Page
|
||||
private Bindings bindingsPage;
|
||||
|
||||
@Before
|
||||
public void beforeBindingsTest() {
|
||||
bindingsPage.navigateTo();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void bindingsTest() {
|
||||
bindingsPage.form().select(BindingsSelect.BROWSER, BindingsOption.REGISTRATION);
|
||||
bindingsPage.form().select(BindingsSelect.REGISTRATION, BindingsOption.RESET_CREDENTIALS);
|
||||
bindingsPage.form().select(BindingsSelect.DIRECT_GRANT, BindingsOption.BROWSER);
|
||||
bindingsPage.form().select(BindingsSelect.RESET_CREDENTIALS, BindingsOption.DIRECT_GRANT);
|
||||
bindingsPage.form().save();
|
||||
|
||||
assertEquals("Success! Your changes have been saved to the realm.", bindingsPage.getSuccessMessage());
|
||||
|
||||
RealmRepresentation realm = testRealmResource().toRepresentation();
|
||||
|
||||
assertEquals("registration", realm.getBrowserFlow());
|
||||
assertEquals("reset credentials", realm.getRegistrationFlow());
|
||||
assertEquals("browser", realm.getDirectGrantFlow());
|
||||
assertEquals("direct grant", realm.getResetCredentialsFlow());
|
||||
assertEquals("clients", realm.getClientAuthenticationFlow());
|
||||
}
|
||||
}
|
|
@ -0,0 +1,117 @@
|
|||
/*
|
||||
* JBoss, Home of Professional Open Source.
|
||||
* Copyright 2012, Red Hat, Inc., and individual contributors
|
||||
* as indicated by the @author tags. See the copyright.txt file in the
|
||||
* distribution for a full listing of individual contributors.
|
||||
*
|
||||
* This is free software; you can redistribute it and/or modify it
|
||||
* under the terms of the GNU Lesser General Public License as
|
||||
* published by the Free Software Foundation; either version 2.1 of
|
||||
* the License, or (at your option) any later version.
|
||||
*
|
||||
* This software is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||
* Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public
|
||||
* License along with this software; if not, write to the Free
|
||||
* Software Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA, or see the FSF site: http://www.fsf.org.
|
||||
*/
|
||||
package org.keycloak.testsuite.console.authentication;
|
||||
|
||||
import org.jboss.arquillian.graphene.page.Page;
|
||||
import static org.junit.Assert.*;
|
||||
import org.junit.Before;
|
||||
import org.junit.Test;
|
||||
import org.keycloak.representations.idm.RealmRepresentation;
|
||||
import org.keycloak.testsuite.arquillian.jira.Jira;
|
||||
import org.keycloak.testsuite.console.AbstractConsoleTest;
|
||||
import org.keycloak.testsuite.console.page.authentication.otppolicy.OTPPolicy;
|
||||
import org.keycloak.testsuite.console.page.authentication.otppolicy.OTPPolicyForm.Digits;
|
||||
import org.keycloak.testsuite.console.page.authentication.otppolicy.OTPPolicyForm.OTPHashAlg;
|
||||
import org.keycloak.testsuite.console.page.authentication.otppolicy.OTPPolicyForm.OTPType;
|
||||
|
||||
/**
|
||||
*
|
||||
* @author <a href="mailto:vramik@redhat.com">Vlastislav Ramik</a>
|
||||
*/
|
||||
public class OTPPolicyTest extends AbstractConsoleTest {
|
||||
|
||||
@Page
|
||||
private OTPPolicy otpPolicyPage;
|
||||
|
||||
@Before
|
||||
public void beforeOTPPolicyTest() {
|
||||
otpPolicyPage.navigateTo();
|
||||
}
|
||||
|
||||
@Test
|
||||
public void otpPolicyTest() {
|
||||
otpPolicyPage.form().setValues(OTPType.COUNTER_BASED, OTPHashAlg.SHA256, Digits.EIGHT, "10", "50");
|
||||
assertEquals("Success! Your changes have been saved to the realm.", otpPolicyPage.getSuccessMessage());
|
||||
|
||||
RealmRepresentation realm = testRealmResource().toRepresentation();
|
||||
assertEquals("hotp", realm.getOtpPolicyType());
|
||||
assertEquals("HmacSHA256", realm.getOtpPolicyAlgorithm());
|
||||
assertEquals(Integer.valueOf(8), realm.getOtpPolicyDigits());
|
||||
assertEquals(Integer.valueOf(10), realm.getOtpPolicyLookAheadWindow());
|
||||
assertEquals(Integer.valueOf(50), realm.getOtpPolicyInitialCounter());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA512, Digits.EIGHT, "10", "40");
|
||||
assertEquals("Success! Your changes have been saved to the realm.", otpPolicyPage.getSuccessMessage());
|
||||
|
||||
realm = testRealmResource().toRepresentation();
|
||||
assertEquals(Integer.valueOf(40), realm.getOtpPolicyPeriod());
|
||||
}
|
||||
|
||||
@Test
|
||||
@Jira(value = "KEYCLOAK-2031")
|
||||
public void invalidValuesTest() {
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "", "30");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, " ", "30");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "no number", "30");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1 2", "30");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
RealmRepresentation realm = testRealmResource().toRepresentation();
|
||||
assertEquals(Integer.valueOf(1), realm.getOtpPolicyLookAheadWindow());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", " ");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "no number");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.TIME_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "1 2");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
realm = testRealmResource().toRepresentation();
|
||||
assertEquals(Integer.valueOf(30), realm.getOtpPolicyPeriod());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.COUNTER_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.COUNTER_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", " ");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.COUNTER_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "no number");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
otpPolicyPage.form().setValues(OTPType.COUNTER_BASED, OTPHashAlg.SHA1, Digits.EMPTY, "1", "1 2");
|
||||
assertEquals("Error! Failed to update test Realm.", otpPolicyPage.getErrorMessage());
|
||||
|
||||
realm = testRealmResource().toRepresentation();
|
||||
assertEquals(Integer.valueOf(0), realm.getOtpPolicyInitialCounter());
|
||||
}
|
||||
}
|
Loading…
Reference in a new issue