Moved MockTerminal and cleaned up some tests

Original commit: elastic/x-pack-elasticsearch@ffb873c826
This commit is contained in:
Ryan Ernst 2016-03-07 12:42:44 -08:00
parent b54e6a7ae6
commit bafbcd9ed3
6 changed files with 68 additions and 91 deletions

View File

@ -11,7 +11,7 @@ import java.nio.file.Path;
import org.elasticsearch.cli.ExitCodes; import org.elasticsearch.cli.ExitCodes;
import org.elasticsearch.cli.UserError; import org.elasticsearch.cli.UserError;
import org.elasticsearch.common.cli.MockTerminal; import org.elasticsearch.cli.MockTerminal;
import org.elasticsearch.common.cli.Terminal; import org.elasticsearch.common.cli.Terminal;
import org.elasticsearch.license.core.License; import org.elasticsearch.license.core.License;
import org.elasticsearch.license.licensor.TestUtils; import org.elasticsearch.license.licensor.TestUtils;

View File

@ -95,14 +95,9 @@ public class ESUsersTool extends MultiCommand {
@Override @Override
protected int execute(Terminal terminal, OptionSet options) throws Exception { protected int execute(Terminal terminal, OptionSet options) throws Exception {
String username = arguments.value(options); String username = arguments.value(options);
String password = passwordOption.value(options); String passwordStr = passwordOption.value(options);
String roles = rolesOption.value(options); String rolesCsv = rolesOption.value(options);
execute(terminal, username, password, roles);
return ExitCodes.OK;
}
// pkg private for testing
void execute(Terminal terminal, String username, String passwordStr, String rolesCsv) throws Exception {
Validation.Error validationError = Validation.ESUsers.validateUsername(username); Validation.Error validationError = Validation.ESUsers.validateUsername(username);
if (validationError != null) { if (validationError != null) {
throw new UserError(ExitCodes.DATA_ERROR, "Invalid username [" + username + "]... " + validationError); throw new UserError(ExitCodes.DATA_ERROR, "Invalid username [" + username + "]... " + validationError);
@ -156,6 +151,7 @@ public class ESUsersTool extends MultiCommand {
} }
attributesChecker.check(terminal); attributesChecker.check(terminal);
return ExitCodes.OK;
} }
} }

View File

@ -76,7 +76,7 @@ public class ShieldFiles {
tempFileView.setPermissions(attributes.permissions()); tempFileView.setPermissions(attributes.permissions());
// Make an attempt to set the username and group to match. If it fails, silently ignore the failure as the user // Make an attempt to set the username and group to match. If it fails, silently ignore the failure as the user
// will be notified by the CheckFileCommand that the ownership has changed and needs to be corrected // will be notified by the FileAttributeChecker that the ownership has changed and needs to be corrected
try { try {
tempFileView.setOwner(attributes.owner()); tempFileView.setOwner(attributes.owner());
} catch (Exception e) { } catch (Exception e) {

View File

@ -14,16 +14,20 @@ import java.util.Locale;
import java.util.Map; import java.util.Map;
import java.util.concurrent.atomic.AtomicReference; import java.util.concurrent.atomic.AtomicReference;
import org.elasticsearch.cli.Command;
import org.elasticsearch.cli.CommandTestCase;
import org.elasticsearch.cli.ExitCodes;
import org.elasticsearch.cli.MockTerminal;
import org.elasticsearch.cli.UserError;
import org.elasticsearch.common.Strings; import org.elasticsearch.common.Strings;
import org.elasticsearch.common.cli.CliTool; import org.elasticsearch.common.cli.CliTool;
import org.elasticsearch.common.cli.MockTerminal;
import org.elasticsearch.common.cli.Terminal; import org.elasticsearch.common.cli.Terminal;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.env.Environment; import org.elasticsearch.env.Environment;
import org.elasticsearch.shield.authc.esusers.FileUserRolesStore; import org.elasticsearch.shield.authc.esusers.FileUserRolesStore;
import org.elasticsearch.shield.authc.support.Hasher; import org.elasticsearch.shield.authc.support.Hasher;
import org.elasticsearch.shield.authc.support.SecuredStringTests; import org.elasticsearch.shield.authc.support.SecuredStringTests;
import org.elasticsearch.test.ESTestCase; import org.junit.Before;
import static org.hamcrest.Matchers.allOf; import static org.hamcrest.Matchers.allOf;
import static org.hamcrest.Matchers.arrayContaining; import static org.hamcrest.Matchers.arrayContaining;
@ -37,74 +41,60 @@ import static org.hamcrest.Matchers.hasSize;
import static org.hamcrest.Matchers.instanceOf; import static org.hamcrest.Matchers.instanceOf;
import static org.hamcrest.Matchers.is; import static org.hamcrest.Matchers.is;
import static org.hamcrest.Matchers.not; import static org.hamcrest.Matchers.not;
import static org.hamcrest.Matchers.notNullValue;
import static org.hamcrest.Matchers.startsWith; import static org.hamcrest.Matchers.startsWith;
public class ESUsersToolTests extends ESTestCase { public class ESUsersToolTests extends CommandTestCase {
public void testUseraddParseAllOptions() throws Exception {
ESUsersTool tool = new ESUsersTool(); // settings used to create an Environment for tools
CliTool.Command command = tool.parse("useradd", args("username -p changeme -r r1,r2,r3")); Settings.Builder settingsBuilder;
assertThat(command, instanceOf(ESUsersTool.Useradd.class));
ESUsersTool.Useradd cmd = (ESUsersTool.Useradd) command; @Before
assertThat(cmd.username, equalTo("username")); public void resetSettings() {
assertThat(new String(cmd.passwd.internalChars()), equalTo("changeme")); // TODO: use jimfs so we can run without SM...
assertThat(cmd.roles, notNullValue()); settingsBuilder = Settings.builder().put("path.home", createTempDir());
assertThat(cmd.roles, arrayContaining("r1", "r2", "r3"));
} }
public void testUseraddExtraArgs() throws Exception { @Override
ESUsersTool tool = new ESUsersTool(); protected Command newCommand() {
CliTool.Command command = tool.parse("useradd", args("username -p changeme -r r1,r2,r3 r4 r6")); return new ESUsersTool(new Environment(settingsBuilder.build()));
assertThat(command, instanceOf(CliTool.Command.Exit.class));
CliTool.Command.Exit exit = (CliTool.Command.Exit) command;
assertThat(exit.status(), is(CliTool.ExitStatus.USAGE));
} }
public void testUseraddParseInvalidUsername() throws Exception { public void testUseraddInvalidUsername() throws Exception {
ESUsersTool tool = new ESUsersTool(); UserError e = expectThrows(UserError.class, () -> {
CliTool.Command command = tool.parse("useradd", args("$34dkl -p changeme -r r1,r2,r3")); execute("useradd", "$34dkl", "-p", "changeme", "-r", "r1");
assertThat(command, instanceOf(CliTool.Command.Exit.class)); });
CliTool.Command.Exit exit = (CliTool.Command.Exit) command; assertEquals(ExitCodes.DATA_ERROR, e.exitCode);
assertThat(exit.status(), is(CliTool.ExitStatus.DATA_ERROR)); assertTrue(e.getMessage(), e.getMessage().contains("Invalid username"));
} }
public void testUseradd_Parse_InvalidRoleName() throws Exception { public void testUseraddInvalidRoleName() throws Exception {
ESUsersTool tool = new ESUsersTool(); UserError e = expectThrows(UserError.class, () -> {
CliTool.Command command = tool.parse("useradd", args("username -p changeme -r $343,r2,r3")); execute("useradd", "username", "-p", "changeme", "-r", "$343");
assertThat(command, instanceOf(CliTool.Command.Exit.class)); });
CliTool.Command.Exit exit = (CliTool.Command.Exit) command; assertEquals(ExitCodes.DATA_ERROR, e.exitCode);
assertThat(exit.status(), is(CliTool.ExitStatus.DATA_ERROR)); assertTrue(e.getMessage(), e.getMessage().contains("Invalid role"));
} }
public void testUseraddParseInvalidPassword() throws Exception { public void testUseraddInvalidPassword() throws Exception {
ESUsersTool tool = new ESUsersTool(); UserError e = expectThrows(UserError.class, () -> {
CliTool.Command command = tool.parse("useradd", args("username -p 123 -r r1,r2,r3")); execute("useradd", "username", "-p", "123", "-r", "r1");
assertThat(command, instanceOf(CliTool.Command.Exit.class)); });
CliTool.Command.Exit exit = (CliTool.Command.Exit) command; assertEquals(ExitCodes.DATA_ERROR, e.exitCode);
assertThat(exit.status(), is(CliTool.ExitStatus.DATA_ERROR)); assertTrue(e.getMessage(), e.getMessage().contains("Invalid password"));
} }
public void testUseraddParseNoUsername() throws Exception { public void testUseraddNoUsername() throws Exception {
ESUsersTool tool = new ESUsersTool(); UserError e = expectThrows(UserError.class, () -> {
CliTool.Command command = tool.parse("useradd", args("-p test123")); execute("useradd");
assertThat(command, instanceOf(CliTool.Command.Exit.class)); });
assertThat(((CliTool.Command.Exit) command).status(), is(CliTool.ExitStatus.USAGE)); assertEquals(ExitCodes.USAGE, e.exitCode);
assertTrue(e.getMessage(), e.getMessage().contains("TBD"));
} }
public void testUseraddParseNoPassword() throws Exception { public void testUseraddParseNoPassword() throws Exception {
ESUsersTool tool = new ESUsersTool(new MockTerminal() { terminal.addSecretInput("changeme");
@Override execute("useradd", "username");
public char[] readSecret(String text) { assertUser("username", "changeme");
return "changeme".toCharArray();
}
});
CliTool.Command command = tool.parse("useradd", args("username"));
assertThat(command, instanceOf(ESUsersTool.Useradd.class));
ESUsersTool.Useradd cmd = (ESUsersTool.Useradd) command;
assertThat(cmd.username, equalTo("username"));
assertThat(new String(cmd.passwd.internalChars()), equalTo("changeme"));
assertThat(cmd.roles, notNullValue());
assertThat(cmd.roles.length, is(0));
} }
public void testUseraddCmdCreate() throws Exception { public void testUseraddCmdCreate() throws Exception {
@ -855,11 +845,6 @@ public class ESUsersToolTests extends ESTestCase {
assertThat(lines, containsInAnyOrder("r1:john.doe", "r2:john.doe", "r3:john.doe")); assertThat(lines, containsInAnyOrder("r1:john.doe", "r2:john.doe", "r3:john.doe"));
} }
private CliTool.ExitStatus execute(CliTool.Command cmd, Settings settings) throws Exception {
Environment env = new Environment(settings);
return cmd.execute(settings, env);
}
private Path writeFile(String content) throws IOException { private Path writeFile(String content) throws IOException {
Path file = createTempFile(); Path file = createTempFile();
Files.write(file, content.getBytes(StandardCharsets.UTF_8)); Files.write(file, content.getBytes(StandardCharsets.UTF_8));

View File

@ -11,7 +11,7 @@ import java.nio.file.attribute.PosixFileAttributeView;
import java.nio.file.attribute.PosixFilePermission; import java.nio.file.attribute.PosixFilePermission;
import java.util.Set; import java.util.Set;
import org.elasticsearch.common.cli.CliToolTestCase; import org.elasticsearch.cli.MockTerminal;
import org.elasticsearch.common.cli.Terminal; import org.elasticsearch.common.cli.Terminal;
import org.elasticsearch.common.settings.Settings; import org.elasticsearch.common.settings.Settings;
import org.elasticsearch.env.Environment; import org.elasticsearch.env.Environment;
@ -26,7 +26,7 @@ public class SystemKeyToolTests extends ESTestCase {
@Before @Before
public void init() throws Exception { public void init() throws Exception {
terminal = new CliToolTestCase.CaptureOutputTerminal(); terminal = new MockTerminal();
Settings settings = Settings.builder() Settings settings = Settings.builder()
.put(Environment.PATH_HOME_SETTING.getKey(), createTempDir()).build(); .put(Environment.PATH_HOME_SETTING.getKey(), createTempDir()).build();
env = new Environment(settings); env = new Environment(settings);

View File

@ -13,12 +13,11 @@ import java.nio.file.attribute.PosixFileAttributeView;
import java.nio.file.attribute.PosixFilePermission; import java.nio.file.attribute.PosixFilePermission;
import java.nio.file.attribute.UserPrincipal; import java.nio.file.attribute.UserPrincipal;
import java.util.HashSet; import java.util.HashSet;
import java.util.List;
import java.util.Set; import java.util.Set;
import com.google.common.jimfs.Configuration; import com.google.common.jimfs.Configuration;
import com.google.common.jimfs.Jimfs; import com.google.common.jimfs.Jimfs;
import org.elasticsearch.common.cli.CliToolTestCase; import org.elasticsearch.cli.MockTerminal;
import org.elasticsearch.test.ESTestCase; import org.elasticsearch.test.ESTestCase;
public class FileAttributesCheckerTests extends ESTestCase { public class FileAttributesCheckerTests extends ESTestCase {
@ -26,9 +25,9 @@ public class FileAttributesCheckerTests extends ESTestCase {
public void testNonExistentFile() throws Exception { public void testNonExistentFile() throws Exception {
Path path = createTempDir().resolve("dne"); Path path = createTempDir().resolve("dne");
FileAttributesChecker checker = new FileAttributesChecker(path); FileAttributesChecker checker = new FileAttributesChecker(path);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
assertTrue(terminal.getTerminalOutput().isEmpty()); assertTrue(terminal.getOutput(), terminal.getOutput().isEmpty());
} }
public void testNoPosix() throws Exception { public void testNoPosix() throws Exception {
@ -36,9 +35,9 @@ public class FileAttributesCheckerTests extends ESTestCase {
try (FileSystem fs = Jimfs.newFileSystem(conf)) { try (FileSystem fs = Jimfs.newFileSystem(conf)) {
Path path = fs.getPath("temp"); Path path = fs.getPath("temp");
FileAttributesChecker checker = new FileAttributesChecker(path); FileAttributesChecker checker = new FileAttributesChecker(path);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
assertTrue(terminal.getTerminalOutput().isEmpty()); assertTrue(terminal.getOutput(), terminal.getOutput().isEmpty());
} }
} }
@ -49,9 +48,9 @@ public class FileAttributesCheckerTests extends ESTestCase {
Files.createFile(path); Files.createFile(path);
FileAttributesChecker checker = new FileAttributesChecker(path); FileAttributesChecker checker = new FileAttributesChecker(path);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
assertTrue(terminal.getTerminalOutput().isEmpty()); assertTrue(terminal.getOutput(), terminal.getOutput().isEmpty());
} }
} }
@ -70,11 +69,10 @@ public class FileAttributesCheckerTests extends ESTestCase {
perms.add(PosixFilePermission.GROUP_READ); perms.add(PosixFilePermission.GROUP_READ);
attrs.setPermissions(perms); attrs.setPermissions(perms);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
List<String> output = terminal.getTerminalOutput(); String output = terminal.getOutput();
assertEquals(output.toString(), 2, output.size()); assertTrue(output, output.contains("permissions of [" + path + "] have changed"));
assertTrue(output.toString(), output.get(0).contains("permissions of [" + path + "] have changed"));
} }
} }
@ -89,11 +87,10 @@ public class FileAttributesCheckerTests extends ESTestCase {
PosixFileAttributeView attrs = Files.getFileAttributeView(path, PosixFileAttributeView.class); PosixFileAttributeView attrs = Files.getFileAttributeView(path, PosixFileAttributeView.class);
attrs.setOwner(newOwner); attrs.setOwner(newOwner);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
List<String> output = terminal.getTerminalOutput(); String output = terminal.getOutput();
assertEquals(output.toString(), 1, output.size()); assertTrue(output, output.contains("Owner of file [" + path + "] used to be"));
assertTrue(output.toString(), output.get(0).contains("Owner of file [" + path + "] used to be"));
} }
} }
@ -108,11 +105,10 @@ public class FileAttributesCheckerTests extends ESTestCase {
PosixFileAttributeView attrs = Files.getFileAttributeView(path, PosixFileAttributeView.class); PosixFileAttributeView attrs = Files.getFileAttributeView(path, PosixFileAttributeView.class);
attrs.setGroup(newGroup); attrs.setGroup(newGroup);
CliToolTestCase.CaptureOutputTerminal terminal = new CliToolTestCase.CaptureOutputTerminal(); MockTerminal terminal = new MockTerminal();
checker.check(terminal); checker.check(terminal);
List<String> output = terminal.getTerminalOutput(); String output = terminal.getOutput();
assertEquals(output.toString(), 1, output.size()); assertTrue(output, output.contains("Group of file [" + path + "] used to be"));
assertTrue(output.toString(), output.get(0).contains("Group of file [" + path + "] used to be"));
} }
} }
} }