Merge "Fix incomplete assertions of manila::backend::service_instance"

This commit is contained in:
Zuul
2025-10-03 14:45:48 +00:00
committed by Gerrit Code Review

View File

@@ -2,64 +2,90 @@ require 'spec_helper'
describe 'manila::backend::service_instance' do
let(:title) {'DEFAULT'}
let(:title) { 'mybackend' }
let :params do
{
:create_service_image => true,
:service_instance_name_template => 'manila_service_instance_%s',
:service_instance_user => 'user1',
:service_instance_password => 'pass1',
:manila_service_keypair_name => 'manila-service',
:path_to_public_key => '~/.ssh/id_rsa.pub',
:path_to_private_key => '~/.ssh/id_rsa',
:max_time_to_build_instance => 300,
:service_instance_security_group => 'manila-service',
:service_instance_flavor_id => 1,
:service_network_name => 'manila_service_network',
:service_network_cidr => '10.254.0.0/16',
:service_network_division_mask => 28,
:interface_driver => 'manila.network.linux.interface.OVSInterfaceDriver',
:connect_share_server_to_tenant_network => false,
:service_instance_user => 'user1',
:service_instance_password => 'pass1',
}
end
shared_examples 'manila::backend::service_instance' do
context 'with default parameters' do
it 'configures service instance' do
expect {
params.each_pair do |config,value|
is_expected.to contain_manila_config("DEFAULT/#{config}").with_value( value )
end
}.to raise_error(Puppet::Error, /Missing required parameter service_image_location/)
it 'fails due to missing service_image_location' do
is_expected.to raise_error(Puppet::Error, /Missing required parameter service_image_location/)
end
end
context 'with service image provided' do
let (:req_params) { params.merge!({
:service_image_name => 'manila-service-image',
:service_image_location => 'http://example.com/manila_service_image.iso',
}) }
before do
params.merge!({
:service_image_location => 'http://example.com/manila_service_image.iso',
})
end
it 'configures service instance' do
is_expected.to contain_manila_config('mybackend/service_image_name').with_value('manila-service-image')
is_expected.to contain_manila_config('mybackend/service_instance_name_template').with_value('manila_service_instance_%s')
is_expected.to contain_manila_config('mybackend/service_instance_user').with_value('user1')
is_expected.to contain_manila_config('mybackend/service_instance_password').with_value('pass1').with_secret(true)
is_expected.to contain_manila_config('mybackend/manila_service_keypair_name').with_value('manila-service')
is_expected.to contain_manila_config('mybackend/path_to_public_key').with_value('~/.ssh/id_rsa.pub')
is_expected.to contain_manila_config('mybackend/path_to_private_key').with_value('~/.ssh/id_rsa')
is_expected.to contain_manila_config('mybackend/max_time_to_build_instance').with_value(300)
is_expected.to contain_manila_config('mybackend/service_instance_security_group').with_value('manila-service')
is_expected.to contain_manila_config('mybackend/service_instance_flavor_id').with_value(1)
is_expected.to contain_manila_config('mybackend/service_network_name').with_value('manila_service_network')
is_expected.to contain_manila_config('mybackend/service_network_cidr').with_value('10.254.0.0/16')
is_expected.to contain_manila_config('mybackend/service_network_division_mask').with_value(28)
is_expected.to contain_manila_config('mybackend/interface_driver').with_value('manila.network.linux.interface.OVSInterfaceDriver')
is_expected.to contain_manila_config('mybackend/connect_share_server_to_tenant_network').with_value(false)
end
it 'creates Glance image' do
is_expected.to contain_glance_image(req_params[:service_image_name]).with(
is_expected.to contain_glance_image('manila-service-image').with(
:ensure => 'present',
:is_public => 'yes',
:container_format => 'bare',
:disk_format => 'qcow2',
:source => req_params[:service_image_location]
)
:source => 'http://example.com/manila_service_image.iso'
)
end
end
context 'with custom service image name' do
before do
params.merge!({
:service_image_name => 'custom-image',
:service_image_location => 'http://example.com/manila_service_image.iso',
})
end
it 'configures service instance' do
is_expected.to contain_manila_config('mybackend/service_image_name').with_value('custom-image')
end
it 'creates Glance image' do
is_expected.to contain_glance_image('custom-image').with(
:ensure => 'present',
:is_public => 'yes',
:container_format => 'bare',
:disk_format => 'qcow2',
:source => 'http://example.com/manila_service_image.iso',
)
end
end
context 'with create_service_image false' do
let (:req_params) { params.merge!({
:create_service_image => false,
:service_image_name => 'manila-service-image',
}) }
before do
params.merge!({
:create_service_image => false,
})
end
it 'does not create Glance image' do
is_expected.to_not contain_glance_image(req_params[:service_image_name])
is_expected.to_not contain_glance_image('manila-service-image')
end
end
end