4a61da58d6
Switch tempest_glance_id_setter and tempest_neutron_id_setter to use openstack client with credentials provided in tempest config. This will allow to run puppet-tempest on standalone node but adds dependancy to openstacklib. Change-Id: I27215a9b0f94db39774e20515eddce4cffd7cadf
45 lines
1.5 KiB
Ruby
45 lines
1.5 KiB
Ruby
require 'puppet/util/inifile'
|
|
require 'puppet/provider/openstack'
|
|
require 'puppet/provider/openstack/auth'
|
|
require 'puppet/provider/openstack/credentials'
|
|
class Puppet::Provider::Tempest < Puppet::Provider::Openstack
|
|
|
|
extend Puppet::Provider::Openstack::Auth
|
|
|
|
def self.tempest_file
|
|
return @tempest_file if @tempest_file
|
|
@tempest_file = Puppet::Util::IniConfig::File.new
|
|
@tempest_file.read(@file_path)
|
|
@tempest_file
|
|
end
|
|
|
|
def self.request(service, action, properties=[], file_path)
|
|
@file_path = file_path
|
|
begin
|
|
super(service, action, properties)
|
|
rescue Puppet::Error::OpenstackAuthInputError => error
|
|
tempest_request(service, action, error, properties)
|
|
end
|
|
end
|
|
|
|
def self.tempest_request(service, action, error, properties=nil)
|
|
@credentials.username = tempest_credentials['admin_user']
|
|
@credentials.password = tempest_credentials['admin_password']
|
|
@credentials.project_name = tempest_credentials['admin_tenant_name']
|
|
@credentials.auth_url = tempest_credentials['auth_endpoint']
|
|
raise error unless @credentials.set?
|
|
Puppet::Provider::Openstack.request(service, action, properties, @credentials)
|
|
end
|
|
|
|
def self.tempest_credentials
|
|
t = {}
|
|
t['admin_user'] = tempest_file['identity']['admin_username']
|
|
t['admin_password'] = tempest_file['identity']['admin_password']
|
|
t['admin_tenant_name'] = tempest_file['identity']['admin_tenant_name']
|
|
t['auth_endpoint'] = tempest_file['identity']['uri']
|
|
return t
|
|
end
|
|
|
|
|
|
end
|