Merge pull request #3813 from mposolda/master
KEYCLOAK-4339 MigrationTest fails to run
This commit is contained in:
commit
beebeaa265
3 changed files with 28 additions and 7 deletions
|
@ -64,7 +64,7 @@ mvn -f testsuite/integration-arquillian/tests/other/adapters/karaf/fuse63/pom.xm
|
|||
clean install \
|
||||
-Pauth-server-wildfly \
|
||||
-Papp-server-fuse63 \
|
||||
-Dfuse63.version=6.3.0.redhat-198
|
||||
-Dfuse63.version=6.3.0.redhat-229
|
||||
````
|
||||
|
||||
### EAP6 with Hawtio
|
||||
|
@ -117,23 +117,24 @@ mvn -f testsuite/integration-arquillian/tests/other/adapters/jboss/eap6-fuse/pom
|
|||
|
||||
### DB migration test
|
||||
|
||||
This will:
|
||||
This test will:
|
||||
- start Keycloak 1.9.8
|
||||
- import realm and some data to MySQL DB
|
||||
- stop Keycloak 1.9.8
|
||||
- start latest KEycloak and update DB from 1.9.8
|
||||
- start latest KEycloak, which automatically updates DB from 1.9.8
|
||||
- Do some test that data are correct
|
||||
|
||||
|
||||
1) Prepare MySQL DB and ensure that MySQL DB is empty. See [../../misc/DatabaseTesting.md](../../misc/DatabaseTesting.md) for some hints for locally prepare Docker MySQL image.
|
||||
|
||||
2) Run the test (Update according to your DB connection):
|
||||
2) Run the test (Update according to your DB connection, versions etc):
|
||||
|
||||
````
|
||||
export DB_HOST=localhost
|
||||
|
||||
mvn -f testsuite/integration-arquillian/pom.xml \
|
||||
clean install \
|
||||
-Pauth-server-wildfly,jpa,auth-server-migration \
|
||||
-Pauth-server-wildfly,jpa,clean-jpa,auth-server-migration \
|
||||
-Dtest=MigrationTest \
|
||||
-Dmigration.mode=auto \
|
||||
-Dmigrated.auth.server.version=1.9.8.Final \
|
||||
|
@ -146,8 +147,7 @@ mvn -f testsuite/integration-arquillian/pom.xml \
|
|||
````
|
||||
|
||||
### JSON export/import migration test
|
||||
This will
|
||||
- start latest Keycloak and import the file, which was previously exported from Keycloak 1.9.8.Final
|
||||
This will start latest Keycloak and import the realm JSON file, which was previously exported from Keycloak 1.9.8.Final
|
||||
|
||||
````
|
||||
mvn -f testsuite/integration-arquillian/pom.xml \
|
||||
|
|
|
@ -35,12 +35,17 @@ import static org.keycloak.testsuite.arquillian.AppServerTestEnricher.getAppServ
|
|||
*/
|
||||
public class DeploymentTargetModifier extends AnnotationDeploymentScenarioGenerator {
|
||||
|
||||
// Will be replaced in runtime by real auth-server-container
|
||||
public static final String AUTH_SERVER_CURRENT = "auth-server-current";
|
||||
|
||||
protected final Logger log = Logger.getLogger(this.getClass());
|
||||
|
||||
@Override
|
||||
public List<DeploymentDescription> generate(TestClass testClass) {
|
||||
List<DeploymentDescription> deployments = super.generate(testClass);
|
||||
|
||||
checkAuthServerTestDeployment(deployments, testClass);
|
||||
|
||||
String appServerQualifier = getAppServerQualifier(
|
||||
testClass.getJavaClass());
|
||||
|
||||
|
@ -56,4 +61,17 @@ public class DeploymentTargetModifier extends AnnotationDeploymentScenarioGenera
|
|||
return deployments;
|
||||
}
|
||||
|
||||
private void checkAuthServerTestDeployment(List<DeploymentDescription> descriptions, TestClass testClass) {
|
||||
for (DeploymentDescription deployment : descriptions) {
|
||||
if (deployment.getTarget() != null) {
|
||||
String containerQualifier = deployment.getTarget().getName();
|
||||
if (AUTH_SERVER_CURRENT.equals(containerQualifier)) {
|
||||
String authServerQualifier = AuthServerTestEnricher.AUTH_SERVER_CONTAINER;
|
||||
log.infof("Setting target container for deployment %s.%s: %s", testClass.getName(), deployment.getName(), authServerQualifier);
|
||||
deployment.setTarget(new TargetDescription(authServerQualifier));
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
|
|
|
@ -23,6 +23,7 @@ import java.util.stream.Collectors;
|
|||
import javax.ws.rs.NotFoundException;
|
||||
|
||||
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.junit.Before;
|
||||
import org.junit.Test;
|
||||
|
@ -52,6 +53,7 @@ import org.keycloak.representations.idm.authorization.PolicyRepresentation;
|
|||
import org.keycloak.storage.UserStorageProvider;
|
||||
import org.keycloak.testsuite.AbstractKeycloakTest;
|
||||
import org.keycloak.testsuite.Assert;
|
||||
import org.keycloak.testsuite.arquillian.DeploymentTargetModifier;
|
||||
import org.keycloak.testsuite.arquillian.migration.Migration;
|
||||
import org.keycloak.testsuite.runonserver.RunHelpers;
|
||||
import org.keycloak.testsuite.runonserver.RunOnServerDeployment;
|
||||
|
@ -78,6 +80,7 @@ public class MigrationTest extends AbstractKeycloakTest {
|
|||
private RealmResource masterRealm;
|
||||
|
||||
@Deployment
|
||||
@TargetsContainer(DeploymentTargetModifier.AUTH_SERVER_CURRENT)
|
||||
public static WebArchive deploy() {
|
||||
return RunOnServerDeployment.create();
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue