Files
puppet-designate/spec/acceptance/basic_designate_spec.rb
Alex Schultz e18e6eb355 Configure keystone authtoken options
Update designate::api to leverage keystone::resource::authtoken to
configure the keystone middleware. This patch also allows designate to
be able to leverage Keystone v3.

Some deprecations:
- designate::api::keystone_tenant is deprecated in favor of
  designate::api::project_name.
- designate::api::keystone_user is deprecated in favor of
  designate::api::username.
- designate::api::keystone_password is deprecated in favor of
  designate::api::password.
- designate::api::keystone_host, designate::api::keystone_port,
  designate::api::keystone_protocol are deprecated in favor of
  designate::api::auth_uri and designate::api_auth_url.
- designate::api::keystone_memcached_servers is deprecated in favor of
  designate::api::memcached_servers.

The patch is backward compatible.

Change-Id: I2cb4076b3e8679adac2722871f8391e750e8b4b0
Closes-Bug: #1604463
2016-07-21 14:12:47 -06:00

72 lines
2.0 KiB
Ruby

require 'spec_helper_acceptance'
describe 'basic designate' do
context 'default parameters' do
it 'should work with no errors' do
pp= <<-EOS
include ::openstack_integration
include ::openstack_integration::repos
include ::openstack_integration::rabbitmq
include ::openstack_integration::mysql
include ::openstack_integration::keystone
rabbitmq_user { 'designate':
admin => true,
password => 'an_even_bigger_secret',
provider => 'rabbitmqctl',
require => Class['rabbitmq'],
}
rabbitmq_user_permissions { 'designate@/':
configure_permission => '.*',
write_permission => '.*',
read_permission => '.*',
provider => 'rabbitmqctl',
require => Class['rabbitmq'],
}
# Designate resources
class { '::designate::db::mysql':
password => 'a_big_secret',
}
class { '::designate::keystone::auth':
password => 'a_big_secret',
}
class { '::designate':
rabbit_userid => 'designate',
rabbit_password => 'an_even_bigger_secret',
rabbit_host => '127.0.0.1',
debug => true,
}
class { '::designate::api':
enabled => true,
auth_strategy => 'keystone',
password => 'a_big_secret',
}
class {'::designate::central':
backend_driver => 'bind9',
}
class { '::designate::backend::bind9':
rndc_config_file => '',
rndc_key_file => '',
}
include ::designate::client
class { '::designate::agent': }
class { '::designate::db':
database_connection => 'mysql+pymysql://designate:a_big_secret@127.0.0.1/designate?charset=utf8',
}
EOS
# Run it twice and test for idempotency
apply_manifest(pp, :catch_failures => true)
apply_manifest(pp, :catch_changes => true)
end
describe port(9001) do
it { is_expected.to be_listening.with('tcp') }
end
end
end