puppet-octavia/spec/classes/octavia_keystone_auth_spec.rb
Takashi Kajinami c748dc5e7b Accept system scope credentials for Keystone API request
This change is the first step to support secure RBAC and allows usage
of system scope credentials for Keystone API request.

This change covers the following two items.
 - assignment of system scope roles to system user
 - credential parameters for authtoken middleware

Depends-on: https://review.opendev.org/804325
Change-Id: I94001758cbbbc348fff238f5c352202c7e283b2b
2021-11-25 23:43:24 +09:00

90 lines
3.4 KiB
Ruby

#
# Unit tests for octavia::keystone::auth
#
require 'spec_helper'
describe 'octavia::keystone::auth' do
shared_examples_for 'octavia::keystone::auth' do
context 'with default class parameters' do
let :params do
{ :password => 'octavia_password' }
end
it { is_expected.to contain_keystone__resource__service_identity('octavia').with(
:configure_user => true,
:configure_user_role => true,
:configure_endpoint => true,
:service_name => 'octavia',
:service_type => 'load-balancer',
:service_description => 'OpenStack Load Balancing Service',
:region => 'RegionOne',
:auth_name => 'octavia',
:password => 'octavia_password',
:email => 'octavia@localhost',
:tenant => 'services',
:roles => ['admin'],
:system_scope => 'all',
:system_roles => [],
:public_url => 'http://127.0.0.1:9876',
:internal_url => 'http://127.0.0.1:9876',
:admin_url => 'http://127.0.0.1:9876',
) }
end
context 'when overriding parameters' do
let :params do
{ :password => 'octavia_password',
:auth_name => 'alt_octavia',
:email => 'alt_octavia@alt_localhost',
:tenant => 'alt_service',
:roles => ['admin', 'service'],
:system_scope => 'atl_all',
:system_roles => ['admin', 'member', 'reader'],
:configure_endpoint => false,
:configure_user => false,
:configure_user_role => false,
:service_description => 'Alternative OpenStack Load Balancing Service',
:service_name => 'alt_service',
:service_type => 'alt_load-balancer',
:region => 'RegionTwo',
:public_url => 'https://10.10.10.10:80',
:internal_url => 'http://10.10.10.11:81',
:admin_url => 'http://10.10.10.12:81' }
end
it { is_expected.to contain_keystone__resource__service_identity('octavia').with(
:configure_user => false,
:configure_user_role => false,
:configure_endpoint => false,
:service_name => 'alt_service',
:service_type => 'alt_load-balancer',
:service_description => 'Alternative OpenStack Load Balancing Service',
:region => 'RegionTwo',
:auth_name => 'alt_octavia',
:password => 'octavia_password',
:email => 'alt_octavia@alt_localhost',
:tenant => 'alt_service',
:roles => ['admin', 'service'],
:system_scope => 'atl_all',
:system_roles => ['admin', 'member', 'reader'],
:public_url => 'https://10.10.10.10:80',
:internal_url => 'http://10.10.10.11:81',
:admin_url => 'http://10.10.10.12:81',
) }
end
end
on_supported_os({
:supported_os => OSDefaults.get_supported_os
}).each do |os,facts|
context "on #{os}" do
let (:facts) do
facts.merge!(OSDefaults.get_facts())
end
it_behaves_like 'octavia::keystone::auth'
end
end
end