Add unit tests for tripleo::profile::base::glance::api
Add missing unit tests for tripleo::profile::base::glance::api . Change-Id: I3d0c5f163761dd595260620f15fd6f78effca84f
This commit is contained in:
parent
828a387ef9
commit
40e01f28f6
123
spec/classes/tripleo_profile_base_glance_api_spec.rb
Normal file
123
spec/classes/tripleo_profile_base_glance_api_spec.rb
Normal file
@ -0,0 +1,123 @@
|
||||
#
|
||||
# Copyright (C) 2019 Red Hat, 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 'spec_helper'
|
||||
|
||||
describe 'tripleo::profile::base::glance::api' do
|
||||
shared_examples_for 'tripleo::profile::base::glance::api' do
|
||||
|
||||
before :each do
|
||||
facts.merge!({ :step => params[:step] })
|
||||
end
|
||||
|
||||
context 'with step less than 3' do
|
||||
let(:params) { {
|
||||
:step => 1,
|
||||
} }
|
||||
|
||||
it {
|
||||
is_expected.to contain_class('tripleo::profile::base::glance::api')
|
||||
is_expected.to_not contain_class('glance')
|
||||
is_expected.to_not contain_class('glance::config')
|
||||
is_expected.to_not contain_class('glance::api::logging')
|
||||
is_expected.to_not contain_class('glance::api')
|
||||
is_expected.to_not contain_class('glance::notify::rabbitmq')
|
||||
}
|
||||
end
|
||||
|
||||
context 'with step 3 on bootstrap node' do
|
||||
let(:params) { {
|
||||
:step => 3,
|
||||
:bootstrap_node => 'node.example.com',
|
||||
:oslomsg_rpc_hosts => [ '192.168.0.1' ],
|
||||
:oslomsg_rpc_username => 'glance1',
|
||||
:oslomsg_rpc_password => 'foo',
|
||||
:oslomsg_rpc_port => '1234',
|
||||
:oslomsg_notify_hosts => [ '192.168.0.2' ],
|
||||
:oslomsg_notify_username => 'glance2',
|
||||
:oslomsg_notify_password => 'baa',
|
||||
:oslomsg_notify_port => '5678',
|
||||
} }
|
||||
|
||||
it {
|
||||
is_expected.to contain_class('tripleo::profile::base::glance::api')
|
||||
is_expected.to contain_class('glance')
|
||||
is_expected.to contain_class('glance::config')
|
||||
is_expected.to contain_class('glance::api::logging')
|
||||
is_expected.to contain_class('glance::api')
|
||||
is_expected.to contain_class('glance::notify::rabbitmq').with(
|
||||
:default_transport_url => 'rabbit://glance1:foo@192.168.0.1:1234/?ssl=0',
|
||||
:notification_transport_url => 'rabbit://glance2:baa@192.168.0.2:5678/?ssl=0',
|
||||
)
|
||||
}
|
||||
end
|
||||
|
||||
context 'with step 3 not on bootstrap node' do
|
||||
let(:params) { {
|
||||
:step => 3,
|
||||
:bootstrap_node => 'other.example.com',
|
||||
} }
|
||||
|
||||
it {
|
||||
is_expected.to contain_class('tripleo::profile::base::glance::api')
|
||||
is_expected.to_not contain_class('glance')
|
||||
is_expected.to_not contain_class('glance::config')
|
||||
is_expected.to_not contain_class('glance::api::logging')
|
||||
is_expected.to_not contain_class('glance::api')
|
||||
is_expected.to_not contain_class('glance::notify::rabbitmq')
|
||||
}
|
||||
end
|
||||
|
||||
context 'with step 4' do
|
||||
let(:params) { {
|
||||
:step => 4,
|
||||
:bootstrap_node => 'node.example.com',
|
||||
:oslomsg_rpc_hosts => [ '192.168.0.1' ],
|
||||
:oslomsg_rpc_username => 'glance1',
|
||||
:oslomsg_rpc_password => 'foo',
|
||||
:oslomsg_rpc_port => '1234',
|
||||
:oslomsg_notify_hosts => [ '192.168.0.2' ],
|
||||
:oslomsg_notify_username => 'glance2',
|
||||
:oslomsg_notify_password => 'baa',
|
||||
:oslomsg_notify_port => '5678',
|
||||
} }
|
||||
|
||||
it {
|
||||
is_expected.to contain_class('tripleo::profile::base::glance::api')
|
||||
is_expected.to contain_class('glance')
|
||||
is_expected.to contain_class('glance::config')
|
||||
is_expected.to contain_class('glance::api::logging')
|
||||
is_expected.to contain_class('glance::api')
|
||||
is_expected.to contain_class('glance::notify::rabbitmq').with(
|
||||
:default_transport_url => 'rabbit://glance1:foo@192.168.0.1:1234/?ssl=0',
|
||||
:notification_transport_url => 'rabbit://glance2:baa@192.168.0.2:5678/?ssl=0',
|
||||
)
|
||||
}
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
|
||||
on_supported_os.each do |os, facts|
|
||||
context "on #{os}" do
|
||||
let(:facts) do
|
||||
facts.merge({ :hostname => 'node.example.com' })
|
||||
end
|
||||
|
||||
it_behaves_like 'tripleo::profile::base::glance::api'
|
||||
end
|
||||
end
|
||||
end
|
3
spec/fixtures/hieradata/default.yaml
vendored
3
spec/fixtures/hieradata/default.yaml
vendored
@ -40,7 +40,10 @@ cinder::backup::nfs::backup_share: '/mnt/backup'
|
||||
cinder::rabbit_password: 'password'
|
||||
cinder::keystone::authtoken::password: 'password'
|
||||
# glance related items
|
||||
glance_api_short_bootstrap_node_name : node
|
||||
glance::api::authtoken::password: 'password'
|
||||
glance::backend::swift::swift_store_user: 'service:glance'
|
||||
glance::backend::swift::swift_store_key: 'foo'
|
||||
# gnocchi related items
|
||||
gnocchi_api_short_bootstrap_node_name: node
|
||||
gnocchi::keystone::authtoken::password: 'password'
|
||||
|
Loading…
x
Reference in New Issue
Block a user