From 7afdd98499b634eb10f7983012e9642ac329f77b Mon Sep 17 00:00:00 2001 From: Bruno Oliveira Date: Thu, 18 May 2017 10:41:56 -0300 Subject: [PATCH] [KEYCLOAK-4869] Integration tests for app-html5 are failing after upgrade to 3.1.0.Final --- misc/keycloak-test-helper/pom.xml | 49 ++++++----- .../org/keycloak/test/page/IndexPage.java | 64 ++++++++++++++ .../org/keycloak/test/page/LoginPage.java | 87 +++++++++++++++++++ .../org/keycloak/test/page/ProfilePage.java | 71 +++++++++++++++ 4 files changed, 250 insertions(+), 21 deletions(-) create mode 100644 misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/IndexPage.java create mode 100644 misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/LoginPage.java create mode 100644 misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/ProfilePage.java diff --git a/misc/keycloak-test-helper/pom.xml b/misc/keycloak-test-helper/pom.xml index 97741bdb12c3..5a9983c09243 100644 --- a/misc/keycloak-test-helper/pom.xml +++ b/misc/keycloak-test-helper/pom.xml @@ -1,5 +1,6 @@ - + 4.0.0 @@ -12,26 +13,32 @@ keycloak-test-helper Helper library to test application using Keycloak. jar + + 3.0.7.Final + - - org.keycloak - keycloak-client-registration-api - 3.2.0.CR1-SNAPSHOT - - - org.keycloak - keycloak-admin-client - 3.2.0.CR1-SNAPSHOT - - - org.jboss.resteasy - resteasy-client - 3.0.7.Final - - - org.jboss.resteasy - resteasy-jackson2-provider - 3.0.7.Final - + + org.keycloak + keycloak-client-registration-api + + + org.keycloak + keycloak-admin-client + + + org.jboss.resteasy + resteasy-client + 3.0.7.Final + + + org.jboss.resteasy + resteasy-jackson2-provider + 3.0.7.Final + + + org.seleniumhq.selenium + selenium-java + provided + diff --git a/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/IndexPage.java b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/IndexPage.java new file mode 100644 index 000000000000..d51f9a1fdb9e --- /dev/null +++ b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/IndexPage.java @@ -0,0 +1,64 @@ +/* + * Copyright 2016 Red Hat, Inc. and/or its affiliates + * and other contributors as indicated by the @author tags. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.keycloak.test.page; + +import org.openqa.selenium.WebElement; +import org.openqa.selenium.support.FindBy; + +/** + * @author Bruno Oliveira + */ +public class IndexPage { + + public static final String UNAUTHORIZED = "401 Unauthorized"; + + @FindBy(name = "loginBtn") + private WebElement loginButton; + + @FindBy(name = "logoutBtn") + private WebElement logoutButton; + + @FindBy(name = "adminBtn") + private WebElement adminButton; + + @FindBy(name = "publicBtn") + private WebElement publicButton; + + @FindBy(name = "securedBtn") + private WebElement securedBtn; + + public void clickLogin() { + loginButton.click(); + } + + public void clickLogout() { + logoutButton.click(); + } + + public void clickAdmin() { + adminButton.click(); + } + + public void clickPublic() { + publicButton.click(); + } + + public void clickSecured() { + securedBtn.click(); + } +} diff --git a/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/LoginPage.java b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/LoginPage.java new file mode 100644 index 000000000000..5c2bed0643d0 --- /dev/null +++ b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/LoginPage.java @@ -0,0 +1,87 @@ +/* + * Copyright 2016 Red Hat, Inc. and/or its affiliates + * and other contributors as indicated by the @author tags. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.keycloak.test.page; + +import org.openqa.selenium.WebElement; +import org.openqa.selenium.support.FindBy; + +/** + * @author Stian Thorgersen + */ +public class LoginPage { + + @FindBy(id = "username") + private WebElement usernameInput; + + @FindBy(id = "password") + private WebElement passwordInput; + + @FindBy(id = "totp") + private WebElement totp; + + @FindBy(id = "rememberMe") + private WebElement rememberMe; + + @FindBy(name = "login") + private WebElement submitButton; + + @FindBy(name = "cancel") + private WebElement cancelButton; + + @FindBy(linkText = "Register") + private WebElement registerLink; + + @FindBy(linkText = "Forgot Password?") + private WebElement resetPasswordLink; + + @FindBy(linkText = "Username") + private WebElement recoverUsernameLink; + + @FindBy(className = "alert-error") + private WebElement loginErrorMessage; + + @FindBy(className = "alert-warning") + private WebElement loginWarningMessage; + + @FindBy(className = "alert-success") + private WebElement loginSuccessMessage; + + + @FindBy(className = "alert-info") + private WebElement loginInfoMessage; + + @FindBy(className = "instruction") + private WebElement instruction; + + + @FindBy(id = "kc-current-locale-link") + private WebElement languageText; + + @FindBy(id = "kc-locale-dropdown") + private WebElement localeDropdown; + + public void login(String username, String password) { + usernameInput.clear(); + usernameInput.sendKeys(username); + + passwordInput.clear(); + passwordInput.sendKeys(password); + + submitButton.click(); + } +} diff --git a/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/ProfilePage.java b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/ProfilePage.java new file mode 100644 index 000000000000..903ee12e7a51 --- /dev/null +++ b/misc/keycloak-test-helper/src/main/java/org/keycloak/test/page/ProfilePage.java @@ -0,0 +1,71 @@ +/* + * Copyright 2016 Red Hat, Inc. and/or its affiliates + * and other contributors as indicated by the @author tags. + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package org.keycloak.test.page; + +import org.openqa.selenium.WebElement; +import org.openqa.selenium.support.FindBy; + +/** + * @author Bruno Oliveira + */ +public class ProfilePage { + + @FindBy(name = "profileBtn") + private WebElement profileButton; + + @FindBy(name = "tokenBtn") + private WebElement tokenButton; + + @FindBy(name = "logoutBtn") + private WebElement logoutButton; + + @FindBy(name = "accountBtn") + private WebElement accountButton; + + @FindBy(id = "token-content") + private WebElement tokenContent; + + @FindBy(id = "username") + private WebElement username; + + public String getUsername() { + return username.getText(); + } + + public void clickProfile() { + profileButton.click(); + } + + public void clickToken() { + tokenButton.click(); + } + + public void clickLogout() { + logoutButton.click(); + } + + public void clickAccount() { + accountButton.click(); + } + + public String getTokenContent() throws Exception { + return tokenContent.getText(); + } + +} +