summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorPete Higgins <pete@peterhiggins.org>2020-08-25 13:03:15 -0700
committerPete Higgins <pete@peterhiggins.org>2020-08-25 13:03:15 -0700
commit270a7fdb50ce7e3a177a33ecd809493955caf461 (patch)
tree911831f61ef4a53b1afc9a9d9d8c4d04bac2b1ff /lib
parent14654259f6a3664636e00b2732b161b36fa2c631 (diff)
downloadchef-270a7fdb50ce7e3a177a33ecd809493955caf461.tar.gz
Update `knife config list` with new behavior and fix tests.
Signed-off-by: Pete Higgins <pete@peterhiggins.org>
Diffstat (limited to 'lib')
-rw-r--r--lib/chef/knife/config_list.rb69
1 files changed, 41 insertions, 28 deletions
diff --git a/lib/chef/knife/config_list.rb b/lib/chef/knife/config_list.rb
index 9646178289..0a5d493273 100644
--- a/lib/chef/knife/config_list.rb
+++ b/lib/chef/knife/config_list.rb
@@ -1,6 +1,5 @@
#
-# Author:: Vivek Singh (<vsingh@chef.io>)
-# Copyright:: Copyright (c) Chef Software Inc.
+# Copyright:: Copyright (c) 2018, Noah Kantrowitz
# License:: Apache License, Version 2.0
#
# Licensed under the Apache License, Version 2.0 (the "License");
@@ -22,9 +21,14 @@ class Chef
class Knife
class ConfigList < Knife
banner "knife config list (options)"
+ category "deprecated"
+
+ TABLE_HEADER = [" Profile", "Client", "Key", "Server"].freeze
deps do
require_relative "../workstation_config_loader"
+ require "tty-screen" unless defined?(TTY::Screen)
+ require "tty-table" unless defined?(TTY::Table)
end
option :ignore_knife_rb,
@@ -91,36 +95,45 @@ class Chef
private
- def render_table(profiles, padding: 2)
- # Replace the home dir in the client key path with ~.
+ def render_table(profiles, padding: 1)
+ rows = []
+ # Render the data to a 2D array that will be used for the table.
profiles.each do |profile|
+ # Replace the home dir in the client key path with ~.
profile[:client_key] = profile[:client_key].to_s.gsub(/^#{Regexp.escape(Dir.home)}/, "~") if profile[:client_key]
+ profile[:profile] = "#{profile[:active] ? "*" : " "}#{profile[:profile]}"
+ rows << profile.values_at(:profile, :client_name, :client_key, :server_url)
end
- # Render the data to a 2D array that will be used for the table.
- table_data = [["", "Profile", "Client", "Key", "Server"]] + profiles.map do |profile|
- [profile[:active] ? "*" : ""] + profile.values_at(:profile, :client_name, :client_key, :server_url).map(&:to_s)
- end
- # Compute column widths.
- column_widths = Array.new(table_data.first.length) do |i|
- table_data.map { |row| row[i].length + padding }.max
- end
- # Special case, the first col gets no padding (because indicator) and last
- # get no padding because last.
- column_widths[0] -= padding
- column_widths[-1] -= padding
- # Build the format string for each row.
- format_string = column_widths.map { |w| "%-#{w}.#{w}s" }.join("")
- format_string << "\n"
- # Print the header row and a separator.
- table = ui.color(format_string % table_data.first, :green)
- table << "-" * column_widths.sum
- table << "\n"
- # Print the rest of the table.
- table_data.drop(1).each do |row|
- table << format_string % row
+
+ table = TTY::Table.new(header: TABLE_HEADER, rows: rows)
+
+ # Rotate the table to vertical if the screen width is less than table width.
+ if table.width > TTY::Screen.width
+ table.orientation = :vertical
+ table.rotate
+ # Add a new line after each profile record.
+ table.render do |renderer|
+ renderer.border do
+ separator ->(row) { (row + 1) % TABLE_HEADER.size == 0 }
+ end
+ # Remove the leading space added of the first column.
+ renderer.filter = Proc.new do |val, row_index, col_index|
+ if col_index == 1 || (row_index) % TABLE_HEADER.size == 0
+ val.strip
+ else
+ val
+ end
+ end
+ end
+ else
+ table.render do |renderer|
+ renderer.border do
+ mid "-"
+ style :green
+ end
+ renderer.padding = [0, padding, 0, 0] # pad right with 2 characters
+ end
end
- # Trim the last newline because ui.output adds one.
- table.chomp!
end
end