Implement Service Validation
Service Validations aims to be used in all OpenStack modules to validate that services are actually running. Example in nova::api where we could validate the Nova API is really working. If it's the case, a Puppet Anchor will be created. This Anchor could be consummed by external tools to validate a deployment workflow and improve the orchestration during an OpenStack deployment. Change-Id: Ia74677b1402c8f872183f873cf9cb73702253874
This commit is contained in:
42
README.md
42
README.md
@@ -119,6 +119,48 @@ array or string; optional; default to undef
|
|||||||
Privileges given to the database user;
|
Privileges given to the database user;
|
||||||
string or array of strings; optional; default to 'ALL'
|
string or array of strings; optional; default to 'ALL'
|
||||||
|
|
||||||
|
|
||||||
|
#### Defined type: openstacklib::service_validation
|
||||||
|
|
||||||
|
The service_validation resource is a library resource that can be used by nova, cinder,
|
||||||
|
ceilometer, etc., to validate that a resource is actually up and running.
|
||||||
|
|
||||||
|
For example, in nova::api you might declare:
|
||||||
|
|
||||||
|
```
|
||||||
|
::openstacklib::service_validation { 'nova-api':
|
||||||
|
command => 'nova list',
|
||||||
|
}
|
||||||
|
```
|
||||||
|
This defined resource creates an exec-anchor pair where the anchor depends upon
|
||||||
|
the successful exec run.
|
||||||
|
|
||||||
|
** Parameters for openstacklib::service_validation: **
|
||||||
|
|
||||||
|
#####`command`
|
||||||
|
Command to run for validating the service;
|
||||||
|
string; required
|
||||||
|
|
||||||
|
#####`service_name`
|
||||||
|
The name of the service to validate;
|
||||||
|
string; optional; default to the $title of the resource, i.e. 'nova-api'
|
||||||
|
|
||||||
|
#####`path`
|
||||||
|
The path of the command to validate the service;
|
||||||
|
string; optional; default to '/usr/bin:/bin:/usr/sbin:/sbin'
|
||||||
|
|
||||||
|
#####`provider`
|
||||||
|
The provider to use for the exec command;
|
||||||
|
string; optional; default to 'shell'
|
||||||
|
|
||||||
|
#####`tries`
|
||||||
|
Number of times to retry validation;
|
||||||
|
string; optional; default to '10'
|
||||||
|
|
||||||
|
#####`try_sleep`
|
||||||
|
Number of seconds between validation attempts;
|
||||||
|
string; optional; default to '2'
|
||||||
|
|
||||||
### Types and Providers
|
### Types and Providers
|
||||||
|
|
||||||
#### Aviator
|
#### Aviator
|
||||||
|
69
manifests/service_validation.pp
Normal file
69
manifests/service_validation.pp
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
#
|
||||||
|
# Copyright (C) 2014 eNovance SAS <licensing@enovance.com>
|
||||||
|
#
|
||||||
|
# Author: Emilien Macchi <emilien.macchi@enovance.com>
|
||||||
|
#
|
||||||
|
# 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.
|
||||||
|
#
|
||||||
|
# == Definition: openstacklib::service_validation
|
||||||
|
#
|
||||||
|
# This resource does service validation for an OpenStack service.
|
||||||
|
#
|
||||||
|
# == Parameters:
|
||||||
|
#
|
||||||
|
# [*command*]
|
||||||
|
# Command to run for validating the service;
|
||||||
|
# string; required
|
||||||
|
#
|
||||||
|
# [*service_name*]
|
||||||
|
# The name of the service to validate;
|
||||||
|
# string; optional; default to the $title of the resource, i.e. 'nova-api'
|
||||||
|
#
|
||||||
|
# [*path*]
|
||||||
|
# The path of the command to validate the service;
|
||||||
|
# string; optional; default to '/usr/bin:/bin:/usr/sbin:/sbin'
|
||||||
|
#
|
||||||
|
# [*provider*]
|
||||||
|
# The provider to use for the exec command;
|
||||||
|
# string; optional; default to 'shell'
|
||||||
|
#
|
||||||
|
# [*tries*]
|
||||||
|
# Number of times to retry validation;
|
||||||
|
# string; optional; default to '10'
|
||||||
|
#
|
||||||
|
# [*try_sleep*]
|
||||||
|
# Number of seconds between validation attempts;
|
||||||
|
# string; optional; default to '2'
|
||||||
|
#
|
||||||
|
define openstacklib::service_validation(
|
||||||
|
$command,
|
||||||
|
$service_name = $name,
|
||||||
|
$path = '/usr/bin:/bin:/usr/sbin:/sbin',
|
||||||
|
$provider = shell,
|
||||||
|
$tries = '10',
|
||||||
|
$try_sleep = '2',
|
||||||
|
) {
|
||||||
|
|
||||||
|
exec { "execute ${service_name} validation":
|
||||||
|
path => $path,
|
||||||
|
provider => $provider,
|
||||||
|
command => $command,
|
||||||
|
tries => $tries,
|
||||||
|
try_sleep => $try_sleep,
|
||||||
|
}
|
||||||
|
|
||||||
|
anchor { "create ${service_name} anchor":
|
||||||
|
require => Exec["execute ${service_name} validation"],
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
73
spec/defines/openstacklib_service_validation_spec.rb
Normal file
73
spec/defines/openstacklib_service_validation_spec.rb
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
#
|
||||||
|
# Copyright (C) 2014 eNovance SAS <licensing@enovance.com>
|
||||||
|
#
|
||||||
|
# Author: Emilien Macchi <emilien.macchi@enovance.com>
|
||||||
|
#
|
||||||
|
# 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 'openstacklib::service_validation' do
|
||||||
|
|
||||||
|
let (:title) { 'nova-api' }
|
||||||
|
|
||||||
|
let :required_params do
|
||||||
|
{ :command => 'nova list' }
|
||||||
|
end
|
||||||
|
|
||||||
|
shared_examples 'openstacklib::service_validation examples' do
|
||||||
|
|
||||||
|
context 'with only required parameters' do
|
||||||
|
let :params do
|
||||||
|
required_params
|
||||||
|
end
|
||||||
|
|
||||||
|
it { should contain_exec("execute #{title} validation").with(
|
||||||
|
:path => '/usr/bin:/bin:/usr/sbin:/sbin',
|
||||||
|
:provider => 'shell',
|
||||||
|
:command => 'nova list',
|
||||||
|
:tries => '10',
|
||||||
|
:try_sleep => '2',
|
||||||
|
)}
|
||||||
|
|
||||||
|
it { should contain_anchor("create #{title} anchor").with(
|
||||||
|
:require => "Exec[execute #{title} validation]",
|
||||||
|
)}
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'when omitting a required parameter command' do
|
||||||
|
let :params do
|
||||||
|
required_params.delete(:command)
|
||||||
|
end
|
||||||
|
it { expect { should raise_error(Puppet::Error) } }
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a Debian osfamily' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => "Debian" }
|
||||||
|
end
|
||||||
|
|
||||||
|
include_examples 'openstacklib::service_validation examples'
|
||||||
|
end
|
||||||
|
|
||||||
|
context 'on a RedHat osfamily' do
|
||||||
|
let :facts do
|
||||||
|
{ :osfamily => 'RedHat' }
|
||||||
|
end
|
||||||
|
|
||||||
|
include_examples 'openstacklib::service_validation examples'
|
||||||
|
end
|
||||||
|
end
|
Reference in New Issue
Block a user