From 5f0cc79562506c84fa091019dad26d71b57098c1 Mon Sep 17 00:00:00 2001 From: Jason Tedor Date: Tue, 10 May 2016 22:06:37 -0400 Subject: [PATCH] Sort plugins in list plugins command This commit modifies the list plugins command to produce deterministic output by sorting the plugins by comparing paths. Relates #18260 --- .../plugins/ListPluginsCommand.java | 18 +++++++++++++----- 1 file changed, 13 insertions(+), 5 deletions(-) diff --git a/core/src/main/java/org/elasticsearch/plugins/ListPluginsCommand.java b/core/src/main/java/org/elasticsearch/plugins/ListPluginsCommand.java index b513be99dcf..c03e70ad4da 100644 --- a/core/src/main/java/org/elasticsearch/plugins/ListPluginsCommand.java +++ b/core/src/main/java/org/elasticsearch/plugins/ListPluginsCommand.java @@ -23,6 +23,9 @@ import java.io.IOException; import java.nio.file.DirectoryStream; import java.nio.file.Files; import java.nio.file.Path; +import java.util.ArrayList; +import java.util.Collections; +import java.util.List; import joptsimple.OptionSet; import org.elasticsearch.cli.Command; @@ -48,12 +51,17 @@ class ListPluginsCommand extends Command { } terminal.println(Terminal.Verbosity.VERBOSE, "Plugins directory: " + env.pluginsFile()); - try (DirectoryStream stream = Files.newDirectoryStream(env.pluginsFile())) { - for (Path plugin : stream) { - terminal.println(plugin.getFileName().toString()); - PluginInfo info = PluginInfo.readFromProperties(env.pluginsFile().resolve(plugin.toAbsolutePath())); - terminal.println(Terminal.Verbosity.VERBOSE, info.toString()); + final List plugins = new ArrayList<>(); + try (DirectoryStream paths = Files.newDirectoryStream(env.pluginsFile())) { + for (Path plugin : paths) { + plugins.add(plugin); } } + Collections.sort(plugins); + for (final Path plugin : plugins) { + terminal.println(plugin.getFileName().toString()); + PluginInfo info = PluginInfo.readFromProperties(env.pluginsFile().resolve(plugin.toAbsolutePath())); + terminal.println(Terminal.Verbosity.VERBOSE, info.toString()); + } } }