Keycloak is a single sign-on solution that supports the Open ID connect standard. However, it does not deliver any test support. This library is intended to fill that gap.
Have a look at our release notes for recent releases and changes.
All artifacts are available on Maven Central Repository under the
group ID com.tngtech.keycloakmock
.
When testing a REST backend that is protected by a Keycloak adapter, the mock allows to generate valid access tokens with configurable content (e.g. roles).
You can create and start the mock directly from the mock
artifact using Maven
<dependency>
<groupId>com.tngtech.keycloakmock</groupId>
<artifactId>mock</artifactId>
<scope>test</scope>
<version>0.7.0</version>
</dependency>
or Gradle
testImplementation 'com.tngtech.keycloakmock:mock:0.7.0'
like this:
import static com.tngtech.keycloakmock.api.ServerConfig.aServerConfig;
import com.tngtech.keycloakmock.api.KeycloakMock;
class Test {
KeycloakMock mock = new KeycloakMock(aServerConfig().withPort(8000).withRealm("master").build());
static {
mock.start();
}
}
You can also use the convenience wrapper mock-junit
for JUnit4
import com.tngtech.keycloakmock.junit.KeycloakMockRule;
public class Test {
@ClassRule
public static KeycloakMockRule mock = new KeycloakMockRule();
// ...
}
or mock-junit5
for JUnit5
import com.tngtech.keycloakmock.junit5.KeycloakMockExtension;
class Test {
@RegisterExtension
static KeycloakMockExtension mock = new KeycloakMockExtension();
// ...
}
to let JUnit start the mock for you.
You can then generate a token of your choosing by providing a TokenConfig:
import static com.tngtech.keycloakmock.api.TokenConfig.aTokenConfig;
class Test {
String accessToken = mock.getAccessToken(aTokenConfig().withRole("ROLE_ADMIN").build());
// ...
}
For a more in-detail test case, please have a look at the AuthenticationTest in our example backend project.
It is also possible to run a stand-alone mock server that provides a login page where a username and
an optional list of roles can be specified. Just get the (self-contained) standalone
artifact,
e.g. from Maven Central,
and run it:
$ java -jar standalone.jar &
Server is running on http://localhost:8000
The stand-alone server can be configured using command line parameters. You can call it
with --help
to get a list of all options.
You can even use it as a replacement in end-to-end tests, as the server is e.g. compatible with
cypress-keycloak
. Have a look at the example-frontend-react project on
this can be set up.
Please note that currently only the authorization code flow and the implicit flow are supported.
This project is licensed under the Apache 2.0 license (see LICENSE).