Use :commands interface for trove-manage
The trove_manage function is quite redundant because it requires the full argument even including the trove-manage command itself. This refactors the function using the :commands definition. Change-Id: Icce7f9a984484c64fe4fec63cfaa93b50d3b4f14
This commit is contained in:
parent
f99ea85cd3
commit
d1d0a1ebc5
@ -11,6 +11,9 @@ class Puppet::Provider::Trove < Puppet::Provider::Openstack
|
|||||||
|
|
||||||
extend Puppet::Provider::Openstack::Auth
|
extend Puppet::Provider::Openstack::Auth
|
||||||
|
|
||||||
|
initvars # so commands will work
|
||||||
|
commands :trove_manage => 'trove-manage'
|
||||||
|
|
||||||
def self.request(service, action, properties=nil)
|
def self.request(service, action, properties=nil)
|
||||||
begin
|
begin
|
||||||
super
|
super
|
||||||
@ -106,8 +109,6 @@ class Puppet::Provider::Trove < Puppet::Provider::Openstack
|
|||||||
end
|
end
|
||||||
|
|
||||||
def trove_manage(*args)
|
def trove_manage(*args)
|
||||||
cmd = args.join(" ")
|
execute([command(:trove_manage)] + args)
|
||||||
output = `#{cmd}`
|
|
||||||
$?.exitstatus
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -37,18 +37,11 @@ Puppet::Type.type(:trove_datastore).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
if trove_manage(['trove-manage', 'datastore_update',
|
trove_manage(['datastore_update', "#{@resource[:name]}", "''"])
|
||||||
"#{@resource[:name]}", "''"]) != 0
|
|
||||||
fail("Failed to create datastore #{@resource[:name]}")
|
|
||||||
end
|
|
||||||
|
|
||||||
if @resource[:version]
|
if @resource[:version]
|
||||||
if trove_manage(['trove-manage', 'datastore_update',
|
trove_manage(['datastore_update', "#{@resource[:name]}", "#{@resource[:version]}"])
|
||||||
"#{@resource[:name]}", "#{@resource[:version]}"]) != 0
|
|
||||||
fail("Failed to set version for datastore #{@resource[:name]}")
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -34,13 +34,12 @@ Puppet::Type.type(:trove_datastore_version).provide(
|
|||||||
end
|
end
|
||||||
|
|
||||||
def create
|
def create
|
||||||
cmd = ['trove-manage', 'datastore_version_update',
|
trove_manage([
|
||||||
|
'datastore_version_update',
|
||||||
"#{@resource[:datastore]}", "#{@resource[:name]}",
|
"#{@resource[:datastore]}", "#{@resource[:name]}",
|
||||||
"#{@resource[:manager]}", "#{@resource[:image_id]}",
|
"#{@resource[:manager]}", "#{@resource[:image_id]}",
|
||||||
"#{@resource[:packages]}", "#{@resource[:active]}"]
|
"#{@resource[:packages]}", "#{@resource[:active]}"
|
||||||
if trove_manage(cmd) != 0
|
])
|
||||||
fail("Failed to create datastore version #{@resource[:name]}")
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
|
@ -57,7 +57,7 @@ describe provider_class do
|
|||||||
context 'without version' do
|
context 'without version' do
|
||||||
it 'creates datastore' do
|
it 'creates datastore' do
|
||||||
expect(provider).to receive(:trove_manage)
|
expect(provider).to receive(:trove_manage)
|
||||||
.with(['trove-manage', 'datastore_update', datastore_name, "''"])
|
.with(['datastore_update', datastore_name, "''"])
|
||||||
.and_return(0)
|
.and_return(0)
|
||||||
provider.create
|
provider.create
|
||||||
end
|
end
|
||||||
@ -72,11 +72,11 @@ describe provider_class do
|
|||||||
|
|
||||||
it 'creates datastore' do
|
it 'creates datastore' do
|
||||||
expect(provider).to receive(:trove_manage)
|
expect(provider).to receive(:trove_manage)
|
||||||
.with(['trove-manage', 'datastore_update', datastore_name, "''"])
|
.with(['datastore_update', datastore_name, "''"])
|
||||||
.and_return(0)
|
.and_return(0)
|
||||||
|
|
||||||
expect(provider).to receive(:trove_manage)
|
expect(provider).to receive(:trove_manage)
|
||||||
.with(['trove-manage', 'datastore_update', datastore_name, "0.1"])
|
.with(['datastore_update', datastore_name, "0.1"])
|
||||||
.and_return(0)
|
.and_return(0)
|
||||||
provider.create
|
provider.create
|
||||||
end
|
end
|
||||||
|
@ -50,7 +50,7 @@ describe provider_class do
|
|||||||
describe '#create' do
|
describe '#create' do
|
||||||
it 'should call trove-manage' do
|
it 'should call trove-manage' do
|
||||||
expect(provider). to receive(:trove_manage).with(
|
expect(provider). to receive(:trove_manage).with(
|
||||||
['trove-manage', 'datastore_version_update', datastore_name,
|
['datastore_version_update', datastore_name,
|
||||||
datastore_version, 'mysql', '1234', 'mysql', '1']
|
datastore_version, 'mysql', '1234', 'mysql', '1']
|
||||||
).and_return(0)
|
).and_return(0)
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user