describe Elasticity::EMR do subject do Elasticity::EMR.new('ACCESS', 'SECRET') end describe '.new' do context 'when arguments are provided' do its(:aws_request) { should == Elasticity::AwsSession.new('ACCESS', 'SECRET', {}) } end context 'when arguments are not provided' do before do ENV.stub(:[]).with('AWS_ACCESS_KEY_ID').and_return('ENV_ACCESS') ENV.stub(:[]).with('AWS_SECRET_ACCESS_KEY').and_return('ENV_SECRET') end it 'should use environment variables' do emr = Elasticity::EMR.new emr.aws_request.should == Elasticity::AwsSession.new('ENV_ACCESS', 'ENV_SECRET', {}) end end end describe '#add_instance_groups' do it 'should send the correct params to AWS' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'AddInstanceGroups', :job_flow_id => 'JOBFLOW_ID', :instance_groups => ['INSTANCE_GROUP_CONFIGS'] }) subject.add_instance_groups('JOBFLOW_ID', ['INSTANCE_GROUP_CONFIGS']) end describe 'return values' do let(:aws_response) do <<-XML j-OALI7TZTQMHX ig-1 ig-2 ig-3 XML end it 'should return an array of the new instance groups IDs' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(aws_response) subject.add_instance_groups('', []).should == ['ig-1', 'ig-2', 'ig-3'] end end context 'when a block is given' do let(:result) { 'RESULT' } it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.add_instance_groups('', []) do |xml| xml.should == 'RESULT' end end end end describe '#add_jobflow_steps' do it 'should add the specified steps to the job flow' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'AddJobFlowSteps', :job_flow_id => 'JOBFLOW_ID', :steps => ['_'] }) subject.add_jobflow_steps('JOBFLOW_ID', {:steps => ['_']}) end context 'when a block is given' do let(:result) { 'RESULT' } it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.add_jobflow_steps('', {}) do |xml| xml.should == 'RESULT' end end end end describe '#describe_jobflows' do let(:describe_jobflows_xml) do <<-XML 2011-04-04T17:41:51Z TERMINATED j-p Pig Job TERMINATED 2011-04-04T17:41:51Z j-h Hive Job XML end it 'should return an array of properly populated JobFlowStatusES' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(describe_jobflows_xml) jobflow_statuses = subject.describe_jobflows jobflow_statuses.map(&:name).should == ['Pig Job', 'Hive Job'] jobflow_statuses.map(&:class).should == [Elasticity::JobFlowStatus, Elasticity::JobFlowStatus] end it 'should describe all jobflows' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'DescribeJobFlows' }) subject.describe_jobflows end context 'when additional parameters are provided' do it 'should pass them through' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :CreatedBefore => '2011-10-04', :operation => 'DescribeJobFlows' }) subject.describe_jobflows(:CreatedBefore => '2011-10-04') end end context 'when a block is given' do let(:result) { 'RESULT' } it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.describe_jobflows do |xml| xml.should == 'RESULT' end end end end describe '#describe_jobflow' do let(:describe_jobflows_xml) { <<-XML j-3UN6WX5RRO2AG The One Job Flow TERMINATED 2011-04-04T17:41:51Z XML } it 'should describe the specified jobflow' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'DescribeJobFlows', :job_flow_ids => ['j-3UN6WX5RRO2AG'] }) subject.describe_jobflow('j-3UN6WX5RRO2AG') end it 'should return a properly populated JobFlowStatus' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(describe_jobflows_xml) jobflow_status = subject.describe_jobflow('_') jobflow_status.should be_a Elasticity::JobFlowStatus jobflow_status.jobflow_id.should == 'j-3UN6WX5RRO2AG' end context 'when a block is given' do let(:result) { 'RESULT' } it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.describe_jobflow('') do |xml| xml.should == 'RESULT' end end end end describe '#describe_jobflow_xml' do before do subject.should_receive(:describe_jobflow).with('JOBFLOW_ID').and_yield('XML_RESULT') end it 'should describe the specified jobflow via raw xml text' do subject.describe_jobflow_xml('JOBFLOW_ID').should == 'XML_RESULT' end end describe '#modify_instance_groups' do it 'should modify the specified instance groups' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'ModifyInstanceGroups', :instance_groups => [{ :instance_group_id => 'ig-2T1HNUO61BG3O', :instance_count => 2 }] }) subject.modify_instance_groups({'ig-2T1HNUO61BG3O' => 2}) end context 'when a block is given' do let(:result) { '_' } it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.modify_instance_groups({}) do |xml| xml.should == '_' end end end end describe '#run_jobflow' do let(:json_response) { <<-JSON {"JobFlowId" : "TEST_JOBFLOW_ID"} JSON } it 'should start the specified job flow' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'RunJobFlow', :jobflow_params => '_' }).and_return(json_response) subject.run_job_flow({:jobflow_params => '_'}) end describe 'jobflow response handling' do it 'should return the ID of the running job flow' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(json_response) subject.run_job_flow({}).should == 'TEST_JOBFLOW_ID' end end context 'when a block is given' do it 'should yield the submission results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(json_response) subject.run_job_flow({}) do |response| response.should == json_response end end end end describe '#terminate_jobflows' do it 'should terminate the specific jobflow' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'TerminateJobFlows', :job_flow_ids => ['j-1'] }) subject.terminate_jobflows('j-1') end context 'when a block is given' do let(:result) { '_' } it 'should yield the termination results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.terminate_jobflows('j-1') do |xml| xml.should == '_' end end end end describe '#set_termination_protection' do context 'when protection is enabled' do it 'should enable protection on the specified jobflows' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'SetTerminationProtection', :termination_protected => true, :job_flow_ids => ['jobflow1', 'jobflow2'] }) subject.set_termination_protection(['jobflow1', 'jobflow2'], true) end end context 'when protection is disabled' do it 'should disable protection on the specified jobflows' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'SetTerminationProtection', :termination_protected => false, :job_flow_ids => ['jobflow1', 'jobflow2'] }) subject.set_termination_protection(['jobflow1', 'jobflow2'], false) end end context 'when protection is not specified' do it 'should enable protection on the specified jobflows' do Elasticity::AwsSession.any_instance.should_receive(:submit).with({ :operation => 'SetTerminationProtection', :termination_protected => true, :job_flow_ids => ['jobflow1', 'jobflow2'] }) subject.set_termination_protection(['jobflow1', 'jobflow2']) end end context 'when a block is given' do let(:result) { '_' } it 'should yield the termination results' do Elasticity::AwsSession.any_instance.should_receive(:submit).and_return(result) subject.set_termination_protection([]) do |xml| xml.should == '_' end end end end describe '#direct' do let(:params) { {:foo => 'bar'} } it 'should pass through directly to the request and return the results of the request' do Elasticity::AwsSession.any_instance.should_receive(:submit).with(params).and_return('RESULT') subject.direct(params).should == 'RESULT' end end describe '#==' do let(:emr1) { Elasticity::EMR.new('ACCESS1', 'SECRET1') } let(:emr2) { Elasticity::EMR.new('ACCESS2', 'SECRET2') } let(:same_object) { emr1 } let(:same_values) { Elasticity::EMR.new('ACCESS1', 'SECRET1') } let(:diff_type) { Object.new } it 'should pass comparison checks' do emr1.should == same_object emr1.should == same_values emr1.should_not == diff_type end end end