fuel-astute/spec/unit/post_deployment_actions/update_no_quorum_policy_spe...

139 lines
4.9 KiB
Ruby

# Copyright 2013 Mirantis, Inc.
#
# Licensed under the Apache License, Version 2.0 (the "License"); you may
# not use this file except in compliance with the License. You may obtain
# a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
# WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
# License for the specific language governing permissions and limitations
# under the License.
require File.join(File.dirname(__FILE__), '../../spec_helper')
describe Astute::UpdateNoQuorumPolicy do
include SpecHelpers
let(:ctx) do
ctx = mock('context')
ctx.stubs(:task_id)
ctx.stubs(:reporter)
ctx.stubs(:status).returns(1 => 'success', 2 => 'success')
ctx
end
let(:deploy_dat1) { [
{'uid' => 1,
'role' => 'primary-controller',
'nodes' => [
{
'uid' => 1,
'slave_name' => 'node-1',
'role' => 'primary-controller'
},
{
'uid' => 2,
'slave_name' => 'node-2',
'role' => 'ceph-osd'
}
]
},
{'uid' => 2,
'role' => 'ceph-osd',
'storage' => {
'objects_ceph' => true
}
}
]
}
let(:deploy_dat3) { [
{'uid' => 1,
'role' => 'primary-controller',
'nodes' => [
{
'uid' => 1,
'slave_name' => 'node-1',
'role' => 'primary-controller'
},
{
'uid' => 2,
'slave_name' => 'node-2',
'role' => 'ceph-osd'
},
{
'uid' => 3,
'slave_name' => 'node-3',
'role' => 'controller'
},
{
'uid' => 4,
'slave_name' => 'node-4',
'role' => 'controller'
}
]
},
{'uid' => 2,
'role' => 'ceph-osd',
'storage' => {
'objects_ceph' => true
}
},
{
'uid' => 3,
'slave_name' => 'node-3',
'role' => 'controller'
},
{
'uid' => 4,
'slave_name' => 'node-4',
'role' => 'controller'
}
]
}
let(:update_no_quorum_policy) { Astute::UpdateNoQuorumPolicy.new }
it 'should change nothing if 2 or less controllers in cluster' do
update_no_quorum_policy.expects(:run_shell_command).never
update_no_quorum_policy.process(deploy_dat1, ctx)
end
it 'should run if deploy success' do
update_no_quorum_policy.expects(:run_shell_command).once.returns(:data => {:exit_code => 0})
update_no_quorum_policy.process(deploy_dat3, ctx)
end
it 'should run if deploy fail' do
ctx.stubs(:status).returns(1 => 'error', 2 => 'success')
update_no_quorum_policy.expects(:run_shell_command).once.returns(:data => {:exit_code => 0})
update_no_quorum_policy.process(deploy_dat3, ctx)
end
it 'should not change deployment status if command fail' do
update_no_quorum_policy.expects(:run_shell_command).once.returns(:data => {:exit_code => 1})
update_no_quorum_policy.process(deploy_dat3, ctx)
ctx.expects(:report_and_update_status).never
end
it 'should not change deployment status if mcollective fail' do
update_no_quorum_policy.expects(:run_shell_command).once.returns(:data => {})
update_no_quorum_policy.process(deploy_dat3, ctx)
ctx.expects(:report_and_update_status).never
end
it 'should run only in primary-controller node' do
update_no_quorum_policy.expects(:run_shell_command).once
.with(ctx, [1], anything)
.returns(:data => {:exit_code => 0})
update_no_quorum_policy.process(deploy_dat3, ctx)
end
end