Class: VagrantPlugins::GPIICi::Command::Ci
- Inherits:
-
Object
- Object
- VagrantPlugins::GPIICi::Command::Ci
- Defined in:
- lib/vagrant-gpii-ci/command/ci.rb
Class Method Summary collapse
Instance Method Summary collapse
- #execute ⇒ Object
-
#help ⇒ Object
Prints the help out for this command.
-
#initialize(argv, env) ⇒ Ci
constructor
A new instance of Ci.
Constructor Details
#initialize(argv, env) ⇒ Ci
Returns a new instance of Ci.
11 12 13 14 15 16 17 18 19 20 21 22 23 24 |
# File 'lib/vagrant-gpii-ci/command/ci.rb', line 11 def initialize(argv, env) super @main_args, @sub_command, @sub_args = split_main_and_subcommand(argv) @subcommands = Vagrant::Registry.new @subcommands.register(:init) do require File.("../init", __FILE__) InitEnvironment end @subcommands.register(:test) do require File.("../test", __FILE__) CITest end end |
Class Method Details
.synopsis ⇒ Object
7 8 9 |
# File 'lib/vagrant-gpii-ci/command/ci.rb', line 7 def self.synopsis "Manages QI environments" end |
Instance Method Details
#execute ⇒ Object
26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/vagrant-gpii-ci/command/ci.rb', line 26 def execute if @main_args.include?("-h") || @main_args.include?("--help") # Print the help for all the sub-commands. puts "GPIICi plugin provides some commands that help the launch of tests automatically" return help end # If we reached this far then we must have a subcommand. If not, # then we also just print the help and exit. command_class = @subcommands.get(@sub_command.to_sym) if @sub_command return help if !command_class || !@sub_command @logger.debug("Invoking command class: #{command_class} #{@sub_args.inspect}") # Initialize and execute the command class command_class.new(@sub_args, @env).execute end |
#help ⇒ Object
Prints the help out for this command
42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 |
# File 'lib/vagrant-gpii-ci/command/ci.rb', line 42 def help opts = OptionParser.new do |o| o. = "Usage: vagrant ci [<args>]" o.separator "" o.separator "Available subcommands:" # Add the available subcommands as separators in order to print them # out as well. keys = [] @subcommands.each { |key, value| keys << key.to_s } keys.sort.each do |key| o.separator " #{key}" end o.separator "" o.separator "For help on any individual command run `vagrant ci <command> -h`" end @env.ui.info(opts.help, prefix: false) end |