Merge pull request #4007 from mhajas/KEYCLOAK-4288
KEYCLOAK-4288 Run tests on EAP7
This commit is contained in:
commit
b18c8c92c5
3 changed files with 173 additions and 0 deletions
|
@ -34,5 +34,20 @@
|
||||||
<properties>
|
<properties>
|
||||||
<app.server>eap</app.server>
|
<app.server>eap</app.server>
|
||||||
</properties>
|
</properties>
|
||||||
|
|
||||||
|
<dependencies>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.wildfly.extras.creaper</groupId>
|
||||||
|
<artifactId>creaper-core</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
<version>1.5.0</version>
|
||||||
|
</dependency>
|
||||||
|
<dependency>
|
||||||
|
<groupId>org.wildfly.core</groupId>
|
||||||
|
<artifactId>wildfly-cli</artifactId>
|
||||||
|
<scope>test</scope>
|
||||||
|
<version>2.2.0.Final</version>
|
||||||
|
</dependency>
|
||||||
|
</dependencies>
|
||||||
|
|
||||||
</project>
|
</project>
|
|
@ -0,0 +1,96 @@
|
||||||
|
/*
|
||||||
|
* Copyright 2017 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.testsuite.adapter.cluster;
|
||||||
|
|
||||||
|
import org.keycloak.testsuite.adapter.page.EmployeeServletDistributable;
|
||||||
|
import org.keycloak.testsuite.arquillian.annotation.*;
|
||||||
|
|
||||||
|
import java.io.*;
|
||||||
|
|
||||||
|
import org.keycloak.testsuite.adapter.servlet.cluster.AbstractSAMLAdapterClusterTest;
|
||||||
|
import org.keycloak.testsuite.adapter.servlet.SendUsernameServlet;
|
||||||
|
|
||||||
|
import org.jboss.arquillian.container.test.api.Deployment;
|
||||||
|
import org.jboss.arquillian.container.test.api.TargetsContainer;
|
||||||
|
import org.jboss.shrinkwrap.api.spec.WebArchive;
|
||||||
|
import org.wildfly.extras.creaper.core.*;
|
||||||
|
import org.wildfly.extras.creaper.core.online.*;
|
||||||
|
import org.wildfly.extras.creaper.core.online.operations.*;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author hmlnarik
|
||||||
|
*/
|
||||||
|
@AppServerContainer("app-server-eap")
|
||||||
|
public class EAPSAMLAdapterClusterTest extends AbstractSAMLAdapterClusterTest {
|
||||||
|
|
||||||
|
@TargetsContainer(value = "app-server-eap-" + NODE_1_NAME)
|
||||||
|
@Deployment(name = EmployeeServletDistributable.DEPLOYMENT_NAME, managed = false)
|
||||||
|
protected static WebArchive employee() {
|
||||||
|
return samlServletDeployment(EmployeeServletDistributable.DEPLOYMENT_NAME, EmployeeServletDistributable.DEPLOYMENT_NAME + "/WEB-INF/web.xml", SendUsernameServlet.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
@TargetsContainer(value = "app-server-eap-" + NODE_2_NAME)
|
||||||
|
@Deployment(name = EmployeeServletDistributable.DEPLOYMENT_NAME + "_2", managed = false)
|
||||||
|
protected static WebArchive employee2() {
|
||||||
|
return employee();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void prepareWorkerNode(Integer managementPort) throws IOException, CliException, NumberFormatException {
|
||||||
|
log.infov("Preparing worker node ({0})", managementPort);
|
||||||
|
|
||||||
|
OnlineManagementClient clientWorkerNodeClient = ManagementClient.online(OnlineOptions
|
||||||
|
.standalone()
|
||||||
|
.hostAndPort("localhost", managementPort)
|
||||||
|
.build());
|
||||||
|
Operations op = new Operations(clientWorkerNodeClient);
|
||||||
|
|
||||||
|
Batch b = new Batch();
|
||||||
|
Address tcppingStack = Address
|
||||||
|
.subsystem("jgroups")
|
||||||
|
.and("stack", "tcpping");
|
||||||
|
b.add(tcppingStack);
|
||||||
|
b.add(tcppingStack.and("transport", "TCP"), Values.of("socket-binding", "jgroups-tcp"));
|
||||||
|
b.add(tcppingStack.and("protocol", "TCPPING"));
|
||||||
|
b.add(tcppingStack.and("protocol", "TCPPING").and("property", "initial_hosts"), Values.of("value", "localhost[" + (7600 + PORT_OFFSET_NODE_1) + "],localhost[" + (7600 + PORT_OFFSET_NODE_2) + "]"));
|
||||||
|
b.add(tcppingStack.and("protocol", "TCPPING").and("property", "port_range"), Values.of("value", "0"));
|
||||||
|
b.add(tcppingStack.and("protocol", "TCPPING").and("property", "num_initial_members"), Values.of("value", "2"));
|
||||||
|
b.add(tcppingStack.and("protocol", "TCPPING").and("property", "timeout"), Values.of("value", "3000"));
|
||||||
|
b.add(tcppingStack.and("protocol", "MERGE3"));
|
||||||
|
b.add(tcppingStack.and("protocol", "FD_SOCK"), Values.of("socket-binding", "jgroups-tcp-fd"));
|
||||||
|
b.add(tcppingStack.and("protocol", "FD"));
|
||||||
|
b.add(tcppingStack.and("protocol", "VERIFY_SUSPECT"));
|
||||||
|
b.add(tcppingStack.and("protocol", "pbcast.NAKACK2"));
|
||||||
|
b.add(tcppingStack.and("protocol", "UNICAST3"));
|
||||||
|
b.add(tcppingStack.and("protocol", "pbcast.STABLE"));
|
||||||
|
b.add(tcppingStack.and("protocol", "pbcast.GMS"));
|
||||||
|
b.add(tcppingStack.and("protocol", "MFC"));
|
||||||
|
b.add(tcppingStack.and("protocol", "FRAG2"));
|
||||||
|
b.writeAttribute(Address.subsystem("jgroups").and("channel", "ee"), "stack", "tcpping");
|
||||||
|
op.batch(b);
|
||||||
|
|
||||||
|
op.add(Address.extension("org.keycloak.keycloak-saml-adapter-subsystem"), Values.of("module", "org.keycloak.keycloak-saml-adapter-subsystem"));
|
||||||
|
op.add(Address.subsystem("keycloak-saml"));
|
||||||
|
|
||||||
|
clientWorkerNodeClient.execute("reload");
|
||||||
|
|
||||||
|
log.infov("Worker node ({0}) Prepared", managementPort);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
|
@ -0,0 +1,62 @@
|
||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
~ 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<web-app xmlns="http://java.sun.com/xml/ns/javaee"
|
||||||
|
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
|
||||||
|
xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd"
|
||||||
|
version="3.0">
|
||||||
|
|
||||||
|
<distributable/>
|
||||||
|
|
||||||
|
<absolute-ordering/>
|
||||||
|
|
||||||
|
<module-name>%CONTEXT_PATH%</module-name>
|
||||||
|
|
||||||
|
<servlet-mapping>
|
||||||
|
<servlet-name>javax.ws.rs.core.Application</servlet-name>
|
||||||
|
<url-pattern>/*</url-pattern>
|
||||||
|
</servlet-mapping>
|
||||||
|
|
||||||
|
<error-page>
|
||||||
|
<location>/error.html</location>
|
||||||
|
</error-page>
|
||||||
|
|
||||||
|
<security-constraint>
|
||||||
|
<web-resource-collection>
|
||||||
|
<web-resource-name>Application</web-resource-name>
|
||||||
|
<url-pattern>/*</url-pattern>
|
||||||
|
</web-resource-collection>
|
||||||
|
<auth-constraint>
|
||||||
|
<role-name>manager</role-name>
|
||||||
|
</auth-constraint>
|
||||||
|
</security-constraint>
|
||||||
|
|
||||||
|
<login-config>
|
||||||
|
<auth-method>KEYCLOAK-SAML</auth-method>
|
||||||
|
<realm-name>demo</realm-name>
|
||||||
|
</login-config>
|
||||||
|
|
||||||
|
<security-role>
|
||||||
|
<role-name>manager</role-name>
|
||||||
|
</security-role>
|
||||||
|
|
||||||
|
<context-param>
|
||||||
|
<param-name>keycloak.sessionIdMapperUpdater.classes</param-name>
|
||||||
|
<param-value>org.keycloak.adapters.saml.wildfly.infinispan.InfinispanSessionCacheIdMapperUpdater</param-value>
|
||||||
|
</context-param>
|
||||||
|
</web-app>
|
Loading…
Reference in a new issue