# Getting started ## Configuring Maven Update your `pom.xml` to include the following (replace `KEYCLOAK_VERSION` with the latest Keycloak release): ```xml KEYCLOAK_VERSION -XX:+ExitOnOutOfMemoryError -XX:+HeapDumpOnOutOfMemoryError -Djava.util.logging.manager=org.jboss.logmanager.LogManager -Djava.util.concurrent.ForkJoinPool.common.threadFactory=io.quarkus.bootstrap.forkjoin.QuarkusForkJoinWorkerThreadFactory org.keycloak.testframework keycloak-test-framework-bom ${keycloak.version} import pom org.keycloak.testframework keycloak-test-framework-core test org.apache.maven.plugins maven-surefire-plugin ${testframework.surefire.args} ``` This will import dependency versions from the test framework BOM. It will also configure the Surefire plugin to pass some arguments to the JVM that are required by the test framework to run properly. ## Writing a test To write a test that uses the new test framework, annotate the test class with `@KeycloakIntegrationTest`, which will start a Keycloak server when the tests are executed. You can also inject various resources for example creating a realm for the tests. For example: ```java @KeycloakIntegrationTest public class MyProviderTest { @InjectRealm ManagedRealm myrealm; @Test public void myTest() { Assertions.assertNotNull(myrealm.admin().toRepresentation()); } } ``` ## Running tests Tests can be executed from Maven or directly from your favourite IDE. For example the following command will run the tests using the default test framework settings: ```shell mvn test -Dtest=MyProviderTest ```