261 lines
8.0 KiB
Ruby
261 lines
8.0 KiB
Ruby
# encoding: UTF-8
|
|
require 'chefspec'
|
|
require 'chefspec/berkshelf'
|
|
|
|
ChefSpec::Coverage.start! { add_filter 'openstack-orchestration' }
|
|
|
|
require 'chef/application'
|
|
|
|
RSpec.configure do |config|
|
|
config.color = true
|
|
config.formatter = :documentation
|
|
config.log_level = :fatal
|
|
end
|
|
|
|
REDHAT_OPTS = {
|
|
platform: 'redhat',
|
|
version: '7.4',
|
|
}.freeze
|
|
UBUNTU_OPTS = {
|
|
platform: 'ubuntu',
|
|
version: '16.04',
|
|
}.freeze
|
|
|
|
shared_context 'orchestration_stubs' do
|
|
before do
|
|
allow_any_instance_of(Chef::Recipe).to receive(:rabbit_servers)
|
|
.and_return '1.1.1.1:5672,2.2.2.2:5672'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:address_for)
|
|
.with('lo')
|
|
.and_return '127.0.1.1'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('token', 'openstack_identity_bootstrap_token')
|
|
.and_return 'bootstrap-token'
|
|
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('db', 'heat')
|
|
.and_return 'heat'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('user', 'guest')
|
|
.and_return 'mq-pass'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('user', 'admin-user')
|
|
.and_return 'admin-pass'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('service', 'openstack-orchestration')
|
|
.and_return 'heat-pass'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('user', 'heat_domain_admin')
|
|
.and_return 'heat_domain_pass'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('user', 'admin')
|
|
.and_return 'admin-pass'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:get_password)
|
|
.with('token', 'orchestration_auth_encryption_key')
|
|
.and_return 'auth_encryption_key_secret'
|
|
allow_any_instance_of(Chef::Recipe).to receive(:rabbit_transport_url)
|
|
.with('orchestration')
|
|
.and_return('rabbit://guest:mypass@127.0.0.1:5672')
|
|
allow(Chef::Application).to receive(:fatal!)
|
|
end
|
|
end
|
|
|
|
shared_examples 'expect runs openstack orchestration common recipe' do
|
|
it 'runs orchestration common recipe' do
|
|
expect(chef_run).to include_recipe 'openstack-orchestration::common'
|
|
end
|
|
end
|
|
|
|
shared_examples 'expect runs openstack common logging recipe' do
|
|
it 'runs logging recipe if node attributes say to' do
|
|
expect(chef_run).to include_recipe 'openstack-common::logging'
|
|
end
|
|
end
|
|
|
|
shared_examples 'expect installs common heat package' do
|
|
it 'installs the openstack-heat common package' do
|
|
expect(chef_run).to upgrade_package 'openstack-heat-common'
|
|
end
|
|
end
|
|
|
|
shared_examples 'expect installs mysql package' do
|
|
it 'installs mysql python packages by default' do
|
|
expect(chef_run).to upgrade_package 'MySQL-python'
|
|
end
|
|
end
|
|
|
|
shared_examples 'expect runs db migrations' do
|
|
it 'runs db migrations' do
|
|
expect(chef_run).to run_execute('heat-manage db_sync').with(user: 'heat', group: 'heat')
|
|
end
|
|
end
|
|
|
|
shared_examples 'expects to create heat directories' do
|
|
it 'creates /etc/heat' do
|
|
expect(chef_run).to create_directory('/etc/heat').with(
|
|
owner: 'heat',
|
|
group: 'heat',
|
|
mode: 0o750
|
|
)
|
|
end
|
|
|
|
it 'creates /etc/heat/environment.d' do
|
|
expect(chef_run).to create_directory('/etc/heat/environment.d').with(
|
|
owner: 'heat',
|
|
group: 'heat',
|
|
mode: 0o750
|
|
)
|
|
end
|
|
end
|
|
|
|
shared_examples 'expects to create heat conf' do
|
|
describe 'heat.conf' do
|
|
let(:file) { chef_run.template('/etc/heat/heat.conf') }
|
|
|
|
it 'creates the heat.conf file' do
|
|
expect(chef_run).to create_template(file.name).with(
|
|
owner: 'heat',
|
|
group: 'heat',
|
|
mode: 0o640
|
|
)
|
|
end
|
|
|
|
it 'sets auth_encryption_key' do
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('DEFAULT', /^auth_encryption_key = auth_encryption_key_secret$/)
|
|
end
|
|
|
|
describe 'default values' do
|
|
it 'has default conf values' do
|
|
[
|
|
%r{^heat_metadata_server_url = http://127.0.0.1:8000$},
|
|
%r{^heat_waitcondition_server_url = http://127.0.0.1:8000/v1/waitcondition$},
|
|
%r{^log_dir = /var/log/heat$},
|
|
/^region_name_for_services = RegionOne$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('DEFAULT', line)
|
|
end
|
|
end
|
|
|
|
it 'has oslo_messaging_notifications conf values' do
|
|
[
|
|
/^driver = heat.openstack.common.notifier.rpc_notifier$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('oslo_messaging_notifications', line)
|
|
end
|
|
end
|
|
|
|
it 'has heat_api binding' do
|
|
[
|
|
/^bind_host = 127.0.0.1$/,
|
|
/^bind_port = 8004$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('heat_api', line)
|
|
end
|
|
end
|
|
|
|
it 'has heat_api_cfn binding' do
|
|
[
|
|
/^bind_host = 127.0.0.1$/,
|
|
/^bind_port = 8000$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('heat_api_cfn', line)
|
|
end
|
|
end
|
|
|
|
it 'sets database connection value' do
|
|
expect(chef_run).to render_config_file(file.name).with_section_content(
|
|
'database', %r{^connection = mysql\+pymysql://heat:heat@127.0.0.1:3306/heat\?charset=utf8$}
|
|
)
|
|
end
|
|
end
|
|
|
|
describe 'has ec2authtoken values' do
|
|
it 'has default ec2authtoken values' do
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('ec2authtoken', %r{^auth_uri = http://127.0.0.1:5000/v3$})
|
|
end
|
|
end
|
|
|
|
describe 'has clients_keystone values' do
|
|
it 'has default clients_keystone values' do
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('clients_keystone', %r{^auth_uri = http://127.0.0.1:5000/$})
|
|
end
|
|
end
|
|
|
|
describe 'has oslo_messaging_rabbit values' do
|
|
it 'has default rabbit values' do
|
|
[
|
|
%r{^transport_url = rabbit://guest:mypass@127.0.0.1:5672$},
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('DEFAULT', line)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'has keystone_authtoken values' do
|
|
it 'has default keystone_authtoken values' do
|
|
[
|
|
%r{^auth_url = http://127.0.0.1:5000/v3$},
|
|
/^auth_type = v3password$/,
|
|
/^username = heat$/,
|
|
/^project_name = service$/,
|
|
/^user_domain_name = Default/,
|
|
/^project_domain_name = Default/,
|
|
/^password = heat-pass$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('keystone_authtoken', line)
|
|
end
|
|
end
|
|
end
|
|
|
|
describe 'has trustee values' do
|
|
it 'has default trustee values' do
|
|
[
|
|
%r{^auth_url = http://127.0.0.1:5000/v3$},
|
|
/^auth_type = v3password$/,
|
|
/^username = heat$/,
|
|
/^password = heat-pass$/,
|
|
/^user_domain_name = Default$/,
|
|
].each do |line|
|
|
expect(chef_run).to render_config_file(file.name).with_section_content('trustee', line)
|
|
end
|
|
end
|
|
end
|
|
end
|
|
end
|
|
|
|
shared_examples 'expects to create heat default.yaml' do
|
|
describe 'default.yaml' do
|
|
let(:file) { chef_run.template('/etc/heat/environment.d/default.yaml') }
|
|
|
|
it 'creates the default.yaml file' do
|
|
expect(chef_run).to create_template(file.name).with(
|
|
owner: 'heat',
|
|
group: 'heat',
|
|
mode: 0o644
|
|
)
|
|
end
|
|
end
|
|
end
|
|
|
|
shared_examples 'logging' do
|
|
context 'with logging enabled' do
|
|
before do
|
|
node.set['openstack']['orchestration']['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 'with logging disabled' do
|
|
before do
|
|
node.set['openstack']['orchestration']['syslog']['use'] = false
|
|
end
|
|
|
|
it "doesn't run logging recipe" do
|
|
expect(chef_run).not_to include_recipe 'openstack-common::logging'
|
|
end
|
|
end
|
|
end
|