ManageIQ/manageiq

View on GitHub
tools/pg_inspector/cli.rb

Summary

Maintainability
A
0 mins
Test Coverage
F
46%
require 'optimist'
require 'pg_inspector/util'
require 'pg_inspector/active_connections_to_yaml'
require 'pg_inspector/servers_to_yaml'
require 'pg_inspector/active_connections_to_human'
require 'pg_inspector/connection_locks'

module PgInspector
  class Cli
    attr_accessor :cmd

    SUB_COMMANDS = {
      :connections => ActiveConnectionsYAML,
      :servers     => ServersYAML,
      :human       => ActiveConnectionsHumanYAML,
      :locks       => LockConnectionYAML
    }.freeze

    def self.run(args)
      new.parse(args).cmd.run
    end

    def parse(args)
      args.shift if args.first == "--" # Handle when called through script/runner
      op_help = operation_help
      Optimist.options(args) do
        banner <<~BANNER
          pg_inspector is a tool to inspect ManageIQ process caused deadlock in PostgreSQL.

            Usage:
              #{$PROGRAM_NAME} operation options_for_operation
              #{$PROGRAM_NAME} options

            Operations:
          #{op_help}
            Use `pg_inspector.rb operation -h' to see help for each operation

            Options:
        BANNER
        stop_on(SUB_COMMANDS.keys.map(&:to_s))
      end
      current_operation = args.shift
      if current_operation && SUB_COMMANDS[current_operation.to_sym]
        self.cmd = SUB_COMMANDS[current_operation.to_sym].new
      else
        Optimist.educate
      end
      cmd.parse_options(args)
      self
    end

    private

    def operation_help
      result = ''
      SUB_COMMANDS.each do |command, klass|
        result << "    #{command}\t\t#{klass::HELP_MSG_SHORT}\n"
      end
      result
    end
  end
end