keycloak-memoizeit
Changes
testsuite/src/test/resources/testrealm.json 14(+14 -0)
Details
diff --git a/testsuite/src/test/java/org/keycloak/testsuite/RequiredActionMultipleActionsTest.java b/testsuite/src/test/java/org/keycloak/testsuite/RequiredActionMultipleActionsTest.java
index 1964ec7..eaa8ced 100644
--- a/testsuite/src/test/java/org/keycloak/testsuite/RequiredActionMultipleActionsTest.java
+++ b/testsuite/src/test/java/org/keycloak/testsuite/RequiredActionMultipleActionsTest.java
@@ -21,62 +21,39 @@
*/
package org.keycloak.testsuite;
-import java.net.MalformedURLException;
-
import org.jboss.arquillian.container.test.api.Deployment;
-import org.jboss.arquillian.drone.api.annotation.Drone;
import org.jboss.arquillian.graphene.page.Page;
import org.jboss.arquillian.junit.Arquillian;
+import org.jboss.shrinkwrap.api.ShrinkWrap;
import org.jboss.shrinkwrap.api.spec.WebArchive;
import org.junit.After;
import org.junit.Assert;
-import org.junit.Before;
+import org.junit.Rule;
import org.junit.Test;
import org.junit.runner.RunWith;
-import org.keycloak.testsuite.pages.AppPage;
-import org.keycloak.testsuite.pages.LoginPage;
-import org.keycloak.testsuite.pages.RegisterPage;
-import org.keycloak.testsuite.pages.TotpPage;
-import org.openqa.selenium.WebDriver;
-import org.picketlink.idm.credential.util.TimeBasedOTP;
+import org.keycloak.testsuite.pages.LoginPasswordUpdatePage;
+import org.keycloak.testsuite.pages.LoginUpdateProfilePage;
/**
* @author <a href="mailto:sthorger@redhat.com">Stian Thorgersen</a>
*/
@RunWith(Arquillian.class)
-public class RequiredActionMultipleActionsTest {
-
- @Deployment(name = "app", testable = false, order = 2)
- public static WebArchive appDeployment() {
- return Deployments.appDeployment();
- }
+public class RequiredActionMultipleActionsTest extends AbstractDroneTest {
- @Deployment(name = "auth-server", testable = false, order = 1)
- public static WebArchive deployment() {
- return Deployments.deployment().addAsResource("testrealm-totp.json", "META-INF/testrealm.json");
+ @Deployment(name = "properties", testable = false, order = 1)
+ public static WebArchive propertiesDeployment() {
+ return ShrinkWrap.create(WebArchive.class, "properties.war").addClass(SystemPropertiesSetter.class)
+ .addAsWebInfResource("web-properties-email-verfication.xml", "web.xml");
}
- @Page
- protected AppPage appPage;
-
- @Drone
- protected WebDriver browser;
-
- @Page
- protected TotpPage totpPage;
+ @Rule
+ public GreenMailRule greenMail = new GreenMailRule();
@Page
- protected LoginPage loginPage;
+ protected LoginPasswordUpdatePage changePasswordPage;
@Page
- protected RegisterPage registerPage;
-
- protected TimeBasedOTP totp;
-
- @Before
- public void before() throws MalformedURLException {
- totp = new TimeBasedOTP();
- }
+ protected LoginUpdateProfilePage updateProfilePage;
@After
public void after() {
@@ -87,8 +64,38 @@ public class RequiredActionMultipleActionsTest {
}
@Test
- public void setupTotp() {
- Assert.fail("Not implemented");
+ public void updateProfileAndPassword() {
+ appPage.open();
+
+ Assert.assertTrue(loginPage.isCurrent());
+
+ loginPage.login("multiple@actions.com", "temp-password");
+
+ if (changePasswordPage.isCurrent()) {
+ updatePassword();
+
+ Assert.assertTrue(updateProfilePage.isCurrent());
+ updateProfile();
+ } else if (updateProfilePage.isCurrent()) {
+ updateProfile();
+
+ Assert.assertTrue(changePasswordPage.isCurrent());
+ updatePassword();
+ } else {
+ Assert.fail("Expected to update password and profile before login");
+ }
+
+ Assert.assertTrue(appPage.isCurrent());
+ Assert.assertEquals("multiple@actions.com", appPage.getUser());
+
+ }
+
+ public void updatePassword() {
+ changePasswordPage.changePassword("new-password", "new-password");
+ }
+
+ public void updateProfile() {
+ updateProfilePage.update("New first", "New last", "new@email.com");
}
}
testsuite/src/test/resources/testrealm.json 14(+14 -0)
diff --git a/testsuite/src/test/resources/testrealm.json b/testsuite/src/test/resources/testrealm.json
index 72a8d61..fea7ab6 100755
--- a/testsuite/src/test/resources/testrealm.json
+++ b/testsuite/src/test/resources/testrealm.json
@@ -45,6 +45,16 @@
]
},
{
+ "username" : "multiple@actions.com",
+ "enabled": true,
+ "requiredActions" : [ "UPDATE_PROFILE", "UPDATE_PASSWORD" ],
+ "email" : "multiple@actions.com",
+ "credentials" : [
+ { "type" : "password",
+ "value" : "temp-password" }
+ ]
+ },
+ {
"username" : "third-party",
"enabled": true,
"credentials" : [
@@ -77,6 +87,10 @@
"roles": ["user"]
},
{
+ "username": "multiple@actions.com",
+ "roles": ["user"]
+ },
+ {
"username": "third-party",
"roles": ["KEYCLOAK_IDENTITY_REQUESTER"]
}