119 lines
3.3 KiB
Ruby
119 lines
3.3 KiB
Ruby
# encoding: UTF-8
|
|
#
|
|
# Cookbook Name:: openstack-block-storage
|
|
|
|
require 'chefspec'
|
|
require 'chefspec/berkshelf'
|
|
|
|
ChefSpec::Coverage.start! { add_filter 'openstack-block-storage' }
|
|
|
|
require 'chef/application'
|
|
|
|
LOG_LEVEL = :fatal
|
|
SUSE_OPTS = {
|
|
platform: 'suse',
|
|
version: '11.03',
|
|
log_level: LOG_LEVEL
|
|
}
|
|
REDHAT_OPTS = {
|
|
platform: 'redhat',
|
|
version: '6.3',
|
|
log_level: LOG_LEVEL
|
|
}
|
|
UBUNTU_OPTS = {
|
|
platform: 'ubuntu',
|
|
version: '12.04',
|
|
log_level: LOG_LEVEL
|
|
}
|
|
|
|
shared_context 'block-storage-stubs' do
|
|
before do
|
|
Chef::Recipe.any_instance.stub(:rabbit_servers)
|
|
.and_return('1.1.1.1:5672,2.2.2.2:5672')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('service', anything)
|
|
.and_return('')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('db', anything)
|
|
.and_return('')
|
|
Chef::Recipe.any_instance.stub(:get_secret)
|
|
.with('openstack_identity_bootstrap_token')
|
|
.and_return('bootstrap-token')
|
|
Chef::Recipe.any_instance.stub(:get_secret)
|
|
.with('rbd_secret_uuid')
|
|
.and_return('b0ff3bba-e07b-49b1-beed-09a45552b1ad')
|
|
Chef::Recipe.any_instance.stub(:get_secret)
|
|
.with('openstack_vmware_secret_name')
|
|
.and_return 'vmware_secret_name'
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('user', 'guest')
|
|
.and_return('mq-pass')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('user', 'solidfire_admin')
|
|
.and_return('solidfire_testpass')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('service', 'netapp')
|
|
.and_return 'netapp-pass'
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('service', 'openstack-block-storage')
|
|
.and_return('cinder-pass')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('service', 'openstack_image_cephx_key')
|
|
.and_return('cephx-key')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('user', 'admin')
|
|
.and_return('emc_test_pass')
|
|
Chef::Recipe.any_instance.stub(:get_password)
|
|
.with('user', 'ibmnas_admin')
|
|
.and_return('test_pass')
|
|
Chef::Application.stub(:fatal!)
|
|
end
|
|
end
|
|
|
|
shared_examples 'common-logging' do
|
|
context 'when syslog.use is true' do
|
|
before do
|
|
node.set['openstack']['block-storage']['syslog']['use'] = true
|
|
end
|
|
|
|
it 'runs logging recipe if node attributes say to' do
|
|
expect(chef_run).to include_recipe 'openstack-common::logging'
|
|
end
|
|
end
|
|
|
|
context 'when syslog.use is false' do
|
|
before do
|
|
node.set['openstack']['block-storage']['syslog']['use'] = false
|
|
end
|
|
|
|
it 'runs logging recipe if node attributes say to' do
|
|
expect(chef_run).to_not include_recipe 'openstack-common::logging'
|
|
end
|
|
end
|
|
end
|
|
|
|
def expect_runs_openstack_common_logging_recipe
|
|
it 'runs logging recipe if node attributes say to' do
|
|
expect(chef_run).to include_recipe 'openstack-common::logging'
|
|
end
|
|
end
|
|
|
|
def expect_creates_cinder_conf(service, user, group, action = :restart) # rubocop:disable MethodLength
|
|
describe 'cinder.conf' do
|
|
let(:file) { chef_run.template('/etc/cinder/cinder.conf') }
|
|
|
|
it 'has proper owner' do
|
|
expect(file.owner).to eq(user)
|
|
expect(file.group).to eq(group)
|
|
end
|
|
|
|
it 'has proper modes' do
|
|
expect(sprintf('%o', file.mode)).to eq '644'
|
|
end
|
|
|
|
it 'notifies service restart' do
|
|
expect(file).to notify(service).to(action)
|
|
end
|
|
end
|
|
end
|