Sha256: 36c5dcf774b8009eb61bc3b599794cac0fe85959fe2eacc02006dbd2733e0919

Contents?: true

Size: 1.77 KB

Versions: 98

Compression:

Stored size: 1.77 KB

Contents

module Fog
  module AWS
    class EMR
      class Real
        require 'fog/aws/parsers/emr/add_instance_groups'

        # adds an instance group to a running cluster
        # http://docs.amazonwebservices.com/ElasticMapReduce/latest/API/API_AddInstanceGroups.html
        # ==== Parameters
        # * JobFlowId <~String> - Job flow in which to add the instance groups
        # * InstanceGroups<~Array> - Instance Groups to add
        #   * 'BidPrice'<~String> - Bid price for each Amazon EC2 instance in the instance group when launching nodes as Spot Instances, expressed in USD.
        #   * 'InstanceCount'<~Integer> - Target number of instances for the instance group
        #   * 'InstanceRole'<~String> - MASTER | CORE | TASK The role of the instance group in the cluster
        #   * 'InstanceType'<~String> - The Amazon EC2 instance type for all instances in the instance group
        #   * 'MarketType'<~String> - ON_DEMAND | SPOT Market type of the Amazon EC2 instances used to create a cluster node
        #   * 'Name'<~String> - Friendly name given to the instance group.
        #
        # ==== Returns
        # * response<~Excon::Response>:
        #   * body<~Hash>:
        def add_instance_groups(job_flow_id, options={})
          if instance_groups = options.delete('InstanceGroups')
            options.merge!(Fog::AWS.indexed_param('InstanceGroups.member.%d', [*instance_groups]))
          end

          request({
            'Action'  => 'AddInstanceGroups',
            'JobFlowId' => job_flow_id,
            :parser   => Fog::Parsers::AWS::EMR::AddInstanceGroups.new,
          }.merge(options))
        end
      end

      class Mock
        def add_instance_groups(job_flow_id, options={})
          Fog::Mock.not_implemented
        end
      end
    end
  end
end

Version data entries

98 entries across 96 versions & 6 rubygems

Version Path
fog-aws-3.11.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.10.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.9.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.8.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.7.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.7 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.6 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.5 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.4 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.3 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.6.2 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.5.2 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.5.1 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.5.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.4.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.3.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.2.0 lib/fog/aws/requests/emr/add_instance_groups.rb
fog-aws-3.1.0 lib/fog/aws/requests/emr/add_instance_groups.rb
vagrant-packet-0.1.1 vendor/bundle/ruby/2.5.0/gems/fog-aws-2.0.1/lib/fog/aws/requests/emr/add_instance_groups.rb
vagrant-packet-0.1.1 vendor/bundle/ruby/2.3.0/gems/fog-aws-2.0.1/lib/fog/aws/requests/emr/add_instance_groups.rb