Class: VagrantPlugins::GPIICi::Command::Ci

Inherits:
Object
  • Object
show all
Defined in:
lib/vagrant-gpii-ci/command/ci.rb

Class Method Summary collapse

Instance Method Summary collapse

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.expand_path("../init", __FILE__)
    InitEnvironment
  end
  @subcommands.register(:test) do
    require File.expand_path("../test", __FILE__)
    CITest
  end
end

Class Method Details

.synopsisObject



7
8
9
# File 'lib/vagrant-gpii-ci/command/ci.rb', line 7

def self.synopsis
  "Manages QI environments"
end

Instance Method Details

#executeObject



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

#helpObject

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.banner = "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