From c6fad2abace669cd6f409bd696092fa09325c74a Mon Sep 17 00:00:00 2001 From: Rafael Monnerat <rafael@nexedi.com> Date: Wed, 27 May 2015 15:06:37 +0200 Subject: [PATCH] check_parameter: Add a new promise checker This checks if a certain parameter is the write one, normally it is required to know if the value is not published but not yet ready. --- setup.py | 1 + slapos/recipe/check_parameter/__init__.py | 60 +++++++++++++++++++ .../check_parameter/template/check_ipv4.py.in | 19 ++++++ .../check_parameter/template/check_ipv6.py.in | 12 ++++ .../template/check_parameter.py.in | 18 ++++++ 5 files changed, 110 insertions(+) create mode 100644 slapos/recipe/check_parameter/__init__.py create mode 100644 slapos/recipe/check_parameter/template/check_ipv4.py.in create mode 100644 slapos/recipe/check_parameter/template/check_ipv6.py.in create mode 100644 slapos/recipe/check_parameter/template/check_parameter.py.in diff --git a/setup.py b/setup.py index bb782562d..f88e2a6f9 100755 --- a/setup.py +++ b/setup.py @@ -87,6 +87,7 @@ setup(name=name, 'check_page_content = slapos.recipe.check_page_content:Recipe', 'check_port_listening = slapos.recipe.check_port_listening:Recipe', 'check_url_available = slapos.recipe.check_url_available:Recipe', + 'check_parameter = slapos.recipe.check_parameter:Recipe', 'cloud9 = slapos.recipe.cloud9:Recipe', 'cloudooo.test = slapos.recipe.erp5_test:CloudoooRecipe', 'condor = slapos.recipe.condor:Recipe', diff --git a/slapos/recipe/check_parameter/__init__.py b/slapos/recipe/check_parameter/__init__.py new file mode 100644 index 000000000..165273647 --- /dev/null +++ b/slapos/recipe/check_parameter/__init__.py @@ -0,0 +1,60 @@ +# vim: set et sts=2: +############################################################################## +# +# Copyright (c) 2015 Vifib SARL and Contributors. All Rights Reserved. +# +# WARNING: This program as such is intended to be used by professional +# programmers who take the whole responsibility of assessing all potential +# consequences resulting from its eventual inadequacies and bugs +# End users who are looking for a ready-to-use solution with commercial +# guarantees and support are strongly adviced to contract a Free Software +# Service Company +# +# This program is Free Software; you can redistribute it and/or +# modify it under the terms of the GNU General Public License +# as published by the Free Software Foundation; either version 3 +# of the License, or (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program; if not, write to the Free Software +# Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. +# +############################################################################## +from slapos.recipe.librecipe import GenericBaseRecipe +import sys + +class Recipe(GenericBaseRecipe): + """ + Check listening port promise + """ + + def install(self): + config = dict( + value=self.options['value'], + python_path=sys.executable, + ) + + if self.options.get('expected-type') == "ipv6": + template = self.getTemplateFilename('check_ipv6.py.in') + + elif self.options.get('expected-type') == "ipv4": + template = self.getTemplateFilename('check_ipv4.py.in') + else: + if self.options.get('expected-value'): + config["expected-value"] = self.options.get('expected-value') + + if self.options.get('expected-not-value'): + config["expected-not-value"] = self.options.get('expected-not-value') + + template = self.getTemplateFilename('check_parameter.py.in') + + promise = self.createExecutable( + self.options['path'], + self.substituteTemplate(template, config)) + + return [promise] diff --git a/slapos/recipe/check_parameter/template/check_ipv4.py.in b/slapos/recipe/check_parameter/template/check_ipv4.py.in new file mode 100644 index 000000000..a6b390a49 --- /dev/null +++ b/slapos/recipe/check_parameter/template/check_ipv4.py.in @@ -0,0 +1,19 @@ +#!%(python_path)s +# BEWARE: This file is operated by slapgrid +# BEWARE: It will be overwritten automatically +import socket + +address = "%(value)s" + +try: + socket.inet_pton(socket.AF_INET, address) +except AttributeError: # no inet_pton here, sorry + try: + socket.inet_aton(address) + except socket.error: + sys.exit(127) + if address.count('.') != 3: + sys.exit(127) + +except socket.error: # not a valid address + sys.exit(127) diff --git a/slapos/recipe/check_parameter/template/check_ipv6.py.in b/slapos/recipe/check_parameter/template/check_ipv6.py.in new file mode 100644 index 000000000..1668d7348 --- /dev/null +++ b/slapos/recipe/check_parameter/template/check_ipv6.py.in @@ -0,0 +1,12 @@ +#!%(python_path)s +# BEWARE: This file is operated by slapgrid +# BEWARE: It will be overwritten automatically +import socket +import sys + +address = "%(value)s" + +try: + socket.inet_pton(socket.AF_INET6, address) +except socket.error: # not a valid address + sys.exit(127) diff --git a/slapos/recipe/check_parameter/template/check_parameter.py.in b/slapos/recipe/check_parameter/template/check_parameter.py.in new file mode 100644 index 000000000..bf3a743c0 --- /dev/null +++ b/slapos/recipe/check_parameter/template/check_parameter.py.in @@ -0,0 +1,18 @@ +#!%(python_path)s +# BEWARE: This file is operated by slapgrid +# BEWARE: It will be overwritten automatically +import socket +import sys + +value = "%(value)s" +expected = "%(expected-value)s" +not_expected = "%(expected-not-value)s" + +if expected != "" and value != expected: + print "FAIL: %s != %s" % (value, expected) + sys.exit(127) + +if not_expected != "" and value == not_expected: + print "FAIL: %s == %s" % (value, not_expected) + sys.exit(127) + -- 2.30.9