Search in sources :

Example 21 with KcAdmExec

use of org.keycloak.testsuite.cli.KcAdmExec in project keycloak by keycloak.

the class KcAdmTest method testGetUserNameExact.

@Test
public void testGetUserNameExact() {
    KcAdmExec.execute("config credentials --server " + serverUrl + " --realm master --user admin --password admin");
    KcAdmExec.execute("create realms -s realm=demorealm -s enabled=true");
    KcAdmExec.execute("create users -r demorealm -s username=testuser");
    KcAdmExec.execute("create users -r demorealm -s username=anothertestuser");
    KcAdmExec.execute("create users -r demorealm -s username=onemoretestuser");
    KcAdmExec exec = execute("add-roles --uusername=testuser --rolename offline_access --target-realm=demorealm");
    Assert.assertEquals(0, exec.exitCode());
}
Also used : KcAdmExec(org.keycloak.testsuite.cli.KcAdmExec) Test(org.junit.Test)

Example 22 with KcAdmExec

use of org.keycloak.testsuite.cli.KcAdmExec in project keycloak by keycloak.

the class KcAdmTest method testNoArgs.

@Test
public void testNoArgs() {
    /*
         *  Test (sub)commands without any arguments
         */
    KcAdmExec exe = KcAdmExec.execute("");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    List<String> lines = exe.stdoutLines();
    Assert.assertTrue("stdout output not empty", lines.size() > 0);
    Assert.assertEquals("stdout first line", "Keycloak Admin CLI", lines.get(0));
    Assert.assertEquals("stdout one but last line", "Use '" + KcAdmExec.CMD + " help <command>' for more information about a given command.", lines.get(lines.size() - 2));
    Assert.assertEquals("stdout last line", "", lines.get(lines.size() - 1));
    /*
         * Test commands without arguments
         */
    exe = KcAdmExec.execute("config");
    assertExitCodeAndStreamSizes(exe, 1, 0, 1);
    Assert.assertEquals("error message", "Sub-command required by '" + CMD + " config' - one of: 'credentials', 'truststore'", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("config credentials");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " config credentials --server SERVER_URL --realm REALM --user USER [--password PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("config truststore");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " config truststore [TRUSTSTORE | --delete] [--trustpass PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("create");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " create ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "No file nor attribute values specified", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("get");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " get ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "CLIENT not specified", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("update");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " update ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "No file nor attribute values specified", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("delete");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " delete ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "CLIENT not specified", exe.stderrLines().get(0));
    // exe = KcAdmExec.execute("get-roles");
    // assertExitCodeAndStdErrSize(exe, 0, 0);
    // try {
    // JsonNode node = JsonSerialization.readValue(exe.stdout(), JsonNode.class);
    // Assert.assertTrue("is JSON array", node.isArray());
    // } catch (IOException e) {
    // throw new AssertionError("Response should be a JSON array", e);
    // }
    // Assert.assertTrue("JSON message returned", exe.stdoutLines().size() > 10);
    // Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    // Assert.assertEquals("help message", "Usage: " + CMD + " get-roles [--cclientid CLIENT_ID | --cid ID] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("add-roles");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " add-roles (--uusername USERNAME | --uid ID) [--cclientid CLIENT_ID | --cid ID] (--rolename NAME | --roleid ID)+ [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "CLIENT not specified", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("remove-roles");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " remove-roles (--uusername USERNAME | --uid ID) [--cclientid CLIENT_ID | --cid ID] (--rolename NAME | --roleid ID)+ [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("set-password");
    assertExitCodeAndStdErrSize(exe, 1, 0);
    Assert.assertTrue("help message returned", exe.stdoutLines().size() > 10);
    Assert.assertEquals("help message", "Usage: " + CMD + " set-password (--username USERNAME | --userid ID) [--new-password PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
    // Assert.assertEquals("error message", "CLIENT not specified", exe.stderrLines().get(0));
    exe = KcAdmExec.execute("help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    lines = exe.stdoutLines();
    Assert.assertTrue("stdout output not empty", lines.size() > 0);
    Assert.assertEquals("stdout first line", "Keycloak Admin CLI", lines.get(0));
    Assert.assertEquals("stdout one but last line", "Use '" + KcAdmExec.CMD + " help <command>' for more information about a given command.", lines.get(lines.size() - 2));
    Assert.assertEquals("stdout last line", "", lines.get(lines.size() - 1));
}
Also used : KcAdmExec(org.keycloak.testsuite.cli.KcAdmExec) Test(org.junit.Test)

Example 23 with KcAdmExec

use of org.keycloak.testsuite.cli.KcAdmExec in project keycloak by keycloak.

the class KcAdmTest method testHelpGlobalOption.

@Test
public void testHelpGlobalOption() {
    /*
         *  Test --help for all commands
         */
    KcAdmExec exe = KcAdmExec.execute("--help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Keycloak Admin CLI", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("create --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " create ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("get --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " get ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("update --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " update ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("delete --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " delete ENDPOINT_URI [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("get-roles --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " get-roles [--cclientid CLIENT_ID | --cid ID] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("add-roles --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " add-roles (--uusername USERNAME | --uid ID) [--cclientid CLIENT_ID | --cid ID] (--rolename NAME | --roleid ID)+ [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("remove-roles --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " remove-roles (--uusername USERNAME | --uid ID) [--cclientid CLIENT_ID | --cid ID] (--rolename NAME | --roleid ID)+ [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("set-password --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " set-password (--username USERNAME | --userid ID) [--new-password PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("config --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " config SUB_COMMAND [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("config credentials --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " config credentials --server SERVER_URL --realm REALM --user USER [--password PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
    exe = KcAdmExec.execute("config truststore --help");
    assertExitCodeAndStdErrSize(exe, 0, 0);
    Assert.assertEquals("stdout first line", "Usage: " + CMD + " config truststore [TRUSTSTORE | --delete] [--trustpass PASSWORD] [ARGUMENTS]", exe.stdoutLines().get(0));
}
Also used : KcAdmExec(org.keycloak.testsuite.cli.KcAdmExec) Test(org.junit.Test)

Example 24 with KcAdmExec

use of org.keycloak.testsuite.cli.KcAdmExec in project keycloak by keycloak.

the class KcAdmSessionTest method testCompositeRoleCreationWithHigherVolumeOfRoles.

@Test
public void testCompositeRoleCreationWithHigherVolumeOfRoles() throws Exception {
    FileConfigHandler handler = initCustomConfigFile();
    try (TempFileResource configFile = new TempFileResource(handler.getConfigFile())) {
        // login as admin
        loginAsUser(configFile.getFile(), serverUrl, "master", "admin", "admin");
        final String realmName = "HigherVolumeRolesRealm";
        // create realm
        KcAdmExec exe = execute(String.format("create realms --config '%s' -s realm=%s -s enabled=true", configFile.getName(), realmName));
        assertExitCodeAndStreamSizes(exe, 0, 0, 1);
        for (int i = 0; i < 20; i++) {
            exe = execute(String.format("create roles --config '%s' -r %s -s name=ROLE%d", configFile.getName(), realmName, i));
            assertExitCodeAndStdErrSize(exe, 0, 1);
        }
        exe = execute(String.format("add-roles --config '%s' -r %s --rname ROLE11 --cclientid realm-management --rolename impersonation --rolename view-users --rolename view-realm --rolename manage-users", configFile.getName(), realmName));
        assertExitCodeAndStreamSizes(exe, 0, 0, 0);
    }
}
Also used : FileConfigHandler(org.keycloak.client.admin.cli.config.FileConfigHandler) KcAdmExec(org.keycloak.testsuite.cli.KcAdmExec) TempFileResource(org.keycloak.testsuite.util.TempFileResource) Test(org.junit.Test)

Example 25 with KcAdmExec

use of org.keycloak.testsuite.cli.KcAdmExec in project keycloak by keycloak.

the class KcAdmTruststoreTest method testTruststore.

@Test
public void testTruststore() throws IOException {
    File truststore = new File("src/test/resources/keystore/keycloak.truststore");
    KcAdmExec exe = execute("config truststore --no-config '" + truststore.getAbsolutePath() + "'");
    assertExitCodeAndStreamSizes(exe, 1, 0, 2);
    Assert.assertEquals("stderr first line", "Unsupported option: --no-config", exe.stderrLines().get(0));
    Assert.assertEquals("try help", "Try '" + OsUtil.CMD + " help config truststore' for more information", exe.stderrLines().get(1));
    // only run this test if ssl protected keycloak server is available
    if (!AUTH_SERVER_SSL_REQUIRED) {
        System.out.println("TEST SKIPPED - This test requires HTTPS. Run with '-Pauth-server-wildfly -Dauth.server.ssl.required=true'");
        return;
    }
    FileConfigHandler handler = initCustomConfigFile();
    try (TempFileResource configFile = new TempFileResource(handler.getConfigFile())) {
        if (runIntermittentlyFailingTests()) {
            // configure truststore
            exe = execute("config truststore --config '" + configFile.getName() + "' '" + truststore.getAbsolutePath() + "'");
            assertExitCodeAndStreamSizes(exe, 0, 0, 0);
            // perform authentication against server - asks for password, then for truststore password
            exe = KcAdmExec.newBuilder().argsLine("config credentials --server " + oauth.AUTH_SERVER_ROOT + " --realm test --user user1" + " --config '" + configFile.getName() + "'").executeAsync();
            exe.waitForStdout("Enter password: ");
            exe.sendToStdin("userpass" + EOL);
            exe.waitForStdout("Enter truststore password: ");
            exe.sendToStdin("secret" + EOL);
            exe.waitCompletion();
            assertExitCodeAndStreamSizes(exe, 0, 2, 1);
            // configure truststore with password
            exe = execute("config truststore --config '" + configFile.getName() + "' --trustpass secret '" + truststore.getAbsolutePath() + "'");
            assertExitCodeAndStreamSizes(exe, 0, 0, 0);
            // perform authentication against server - asks for password, then for truststore password
            exe = KcAdmExec.newBuilder().argsLine("config credentials --server " + oauth.AUTH_SERVER_ROOT + " --realm test --user user1" + " --config '" + configFile.getName() + "'").executeAsync();
            exe.waitForStdout("Enter password: ");
            exe.sendToStdin("userpass" + EOL);
            exe.waitCompletion();
            assertExitCodeAndStreamSizes(exe, 0, 1, 1);
        } else {
            System.out.println("TEST SKIPPED PARTIALLY - This test currently suffers from intermittent failures. Use -Dtest.intermittent=true to run it in full.");
        }
    }
    // configure truststore with password
    exe = execute("config truststore --trustpass secret '" + truststore.getAbsolutePath() + "'");
    assertExitCodeAndStreamSizes(exe, 0, 0, 0);
    // perform authentication against server - asks for password, then for truststore password
    exe = execute("config credentials --server " + serverUrl + " --realm test --user user1 --password userpass");
    assertExitCodeAndStreamSizes(exe, 0, 0, 1);
    exe = execute("config truststore --delete");
    assertExitCodeAndStreamSizes(exe, 0, 0, 0);
    exe = execute("config truststore --delete '" + truststore.getAbsolutePath() + "'");
    assertExitCodeAndStreamSizes(exe, 1, 0, 2);
    Assert.assertEquals("incompatible", "Option --delete is mutually exclusive with specifying a TRUSTSTORE", exe.stderrLines().get(0));
    Assert.assertEquals("try help", "Try '" + CMD + " help config truststore' for more information", exe.stderrLines().get(1));
    exe = execute("config truststore --delete --trustpass secret");
    assertExitCodeAndStreamSizes(exe, 1, 0, 2);
    Assert.assertEquals("no truststore error", "Options --trustpass and --delete are mutually exclusive", exe.stderrLines().get(0));
    Assert.assertEquals("try help", "Try '" + CMD + " help config truststore' for more information", exe.stderrLines().get(1));
    FileConfigHandler cfghandler = new FileConfigHandler();
    cfghandler.setConfigFile(DEFAULT_CONFIG_FILE_PATH);
    ConfigData config = cfghandler.loadConfig();
    Assert.assertNull("truststore null", config.getTruststore());
    Assert.assertNull("trustpass null", config.getTrustpass());
    // perform no-config CRUD test against ssl protected endpoint
    testCRUDWithOnTheFlyAuth(serverUrl, "--user user1 --password userpass", " --truststore '" + truststore.getAbsolutePath() + "' --trustpass secret", "Logging into " + serverUrl + " as user user1 of realm test");
}
Also used : FileConfigHandler(org.keycloak.client.admin.cli.config.FileConfigHandler) ConfigData(org.keycloak.client.admin.cli.config.ConfigData) KcAdmExec(org.keycloak.testsuite.cli.KcAdmExec) File(java.io.File) TempFileResource(org.keycloak.testsuite.util.TempFileResource) Test(org.junit.Test)

Aggregations

KcAdmExec (org.keycloak.testsuite.cli.KcAdmExec)27 Test (org.junit.Test)25 FileConfigHandler (org.keycloak.client.admin.cli.config.FileConfigHandler)10 TempFileResource (org.keycloak.testsuite.util.TempFileResource)9 File (java.io.File)8 ClientRepresentation (org.keycloak.representations.idm.ClientRepresentation)4 ConfigData (org.keycloak.client.admin.cli.config.ConfigData)3 FileOutputStream (java.io.FileOutputStream)2 RealmResource (org.keycloak.admin.client.resource.RealmResource)2 RealmConfigData (org.keycloak.client.admin.cli.config.RealmConfigData)2 TypeReference (com.fasterxml.jackson.core.type.TypeReference)1 ObjectNode (com.fasterxml.jackson.databind.node.ObjectNode)1 ByteArrayInputStream (java.io.ByteArrayInputStream)1 Closeable (java.io.Closeable)1 IOException (java.io.IOException)1 Arrays (java.util.Arrays)1 List (java.util.List)1 Collectors (java.util.stream.Collectors)1 StreamSupport (java.util.stream.StreamSupport)1 Matchers.equalTo (org.hamcrest.Matchers.equalTo)1