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;
|
||||
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
|
||||
|
||||
#### 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