From f48106c83b81735fe9e338037064ec4d168ea429 Mon Sep 17 00:00:00 2001 From: Andrew Butcher Date: Fri, 24 Mar 2017 13:09:58 -0400 Subject: Add oo_version_gte_X_X_or_Y_Y version comparison filters. --- filter_plugins/openshift_version.py | 98 +++++++++++++++++++++++++++++++++++++ 1 file changed, 98 insertions(+) create mode 100644 filter_plugins/openshift_version.py diff --git a/filter_plugins/openshift_version.py b/filter_plugins/openshift_version.py new file mode 100644 index 000000000..df8f565f0 --- /dev/null +++ b/filter_plugins/openshift_version.py @@ -0,0 +1,98 @@ +#!/usr/bin/python + +# -*- coding: utf-8 -*- +# vim: expandtab:tabstop=4:shiftwidth=4 +""" +Custom version comparison filters for use in openshift-ansible +""" + +# pylint can't locate distutils.version within virtualenv +# https://github.com/PyCQA/pylint/issues/73 +# pylint: disable=no-name-in-module, import-error +from distutils.version import LooseVersion + + +def gte_function_builder(name, versions): + """ + Build and return a version comparison function. + + Ex: name = 'oo_version_gte_3_1_or_1_1' + versions = {'enterprise': '3.1', 'origin': '1.1'} + + returns oo_version_gte_3_1_or_1_1, a function which based on the + version and deployment type will return true if the provided + version is greater than or equal to the function's version + """ + enterprise_version = versions['enterprise'] + origin_version = versions['origin'] + + def _gte_function(version, deployment_type): + """ + Dynamic function created by gte_function_builder. + + Ex: version = '3.1' + deployment_type = 'openshift-enterprise' + returns True/False + """ + version_gte = False + if 'enterprise' in deployment_type: + if str(version) >= LooseVersion(enterprise_version): + version_gte = True + elif 'origin' in deployment_type: + if str(version) >= LooseVersion(origin_version): + version_gte = True + return version_gte + _gte_function.__name__ = name + return _gte_function + + +# pylint: disable=too-few-public-methods +class FilterModule(object): + """ + Filters for version checking. + """ + #: The major versions to start incrementing. (enterprise, origin) + majors = [(3, 1)] + + #: The minor version to start incrementing + minor = 3 + #: The number of iterations to increment + minor_iterations = 10 + + def __init__(self): + """ + Creates a new FilterModule for ose version checking. + """ + self._filters = {} + # For each major version + for enterprise, origin in self.majors: + # For each minor version in the range + for minor in range(self.minor, self.minor_iterations): + # Create the function name + func_name = 'oo_version_gte_{}_{}_or_{}_{}'.format( + enterprise, minor, origin, minor) + # Create the function with the builder + func = gte_function_builder( + func_name, { + 'enterprise': '{}.{}.0'.format(enterprise, minor), + 'origin': '{}.{}.0'.format(origin, minor) + }) + # Add the function to the mapping + self._filters[func_name] = func + + # Create filters with special versioning requirements + self._filters['oo_version_gte_3_1_or_1_1'] = gte_function_builder('oo_version_gte_3_1_or_1_1', + {'enterprise': '3.0.2.905', + 'origin': '1.1.0'}) + self._filters['oo_version_gte_3_1_1_or_1_1_1'] = gte_function_builder('oo_version_gte_3_1_or_1_1', + {'enterprise': '3.1.1', + 'origin': '1.1.1'}) + self._filters['oo_version_gte_3_2_or_1_2'] = gte_function_builder('oo_version_gte_3_2_or_1_2', + {'enterprise': '3.1.1.901', + 'origin': '1.2.0'}) + + def filters(self): + """ + Return the filters mapping. + """ + return self._filters -- cgit v1.2.3 From fedcc4c28b897ae6a18e4a03eab1f0c2a72c2889 Mon Sep 17 00:00:00 2001 From: Andrew Butcher Date: Mon, 27 Mar 2017 16:09:40 -0400 Subject: Use oo_version_gte_3_6+ for future versions and treat 1.x origin as legacy. Add tests. --- filter_plugins/openshift_version.py | 87 +++++++++++++++++++++++++------------ test/openshift_version_tests.py | 72 ++++++++++++++++++++++++++++++ 2 files changed, 131 insertions(+), 28 deletions(-) create mode 100644 test/openshift_version_tests.py diff --git a/filter_plugins/openshift_version.py b/filter_plugins/openshift_version.py index df8f565f0..1403e9dcc 100644 --- a/filter_plugins/openshift_version.py +++ b/filter_plugins/openshift_version.py @@ -12,7 +12,7 @@ Custom version comparison filters for use in openshift-ansible from distutils.version import LooseVersion -def gte_function_builder(name, versions): +def legacy_gte_function_builder(name, versions): """ Build and return a version comparison function. @@ -46,50 +46,81 @@ def gte_function_builder(name, versions): return _gte_function +def gte_function_builder(name, gte_version): + """ + Build and return a version comparison function. + + Ex: name = 'oo_version_gte_3_6' + version = '3.6' + + returns oo_version_gte_3_6, a function which based on the + version will return true if the provided version is greater + than or equal to the function's version + """ + def _gte_function(version): + """ + Dynamic function created by gte_function_builder. + + Ex: version = '3.1' + returns True/False + """ + version_gte = False + if str(version) >= LooseVersion(gte_version): + version_gte = True + return version_gte + _gte_function.__name__ = name + return _gte_function + + # pylint: disable=too-few-public-methods class FilterModule(object): """ Filters for version checking. """ - #: The major versions to start incrementing. (enterprise, origin) - majors = [(3, 1)] - - #: The minor version to start incrementing - minor = 3 - #: The number of iterations to increment - minor_iterations = 10 + # Each element of versions is composed of (major, minor_start, minor_end) + # Origin began versioning 3.x with 3.6, so begin 3.x with 3.6. + versions = [(3, 6, 10)] def __init__(self): """ Creates a new FilterModule for ose version checking. """ self._filters = {} - # For each major version - for enterprise, origin in self.majors: + + # For each set of (major, minor, minor_iterations) + for major, minor_start, minor_end in self.versions: # For each minor version in the range - for minor in range(self.minor, self.minor_iterations): + for minor in range(minor_start, minor_end): # Create the function name - func_name = 'oo_version_gte_{}_{}_or_{}_{}'.format( - enterprise, minor, origin, minor) + func_name = 'oo_version_gte_{}_{}'.format(major, minor) # Create the function with the builder - func = gte_function_builder( - func_name, { - 'enterprise': '{}.{}.0'.format(enterprise, minor), - 'origin': '{}.{}.0'.format(origin, minor) - }) + func = gte_function_builder(func_name, "{}.{}.0".format(major, minor)) # Add the function to the mapping self._filters[func_name] = func - # Create filters with special versioning requirements - self._filters['oo_version_gte_3_1_or_1_1'] = gte_function_builder('oo_version_gte_3_1_or_1_1', - {'enterprise': '3.0.2.905', - 'origin': '1.1.0'}) - self._filters['oo_version_gte_3_1_1_or_1_1_1'] = gte_function_builder('oo_version_gte_3_1_or_1_1', - {'enterprise': '3.1.1', - 'origin': '1.1.1'}) - self._filters['oo_version_gte_3_2_or_1_2'] = gte_function_builder('oo_version_gte_3_2_or_1_2', - {'enterprise': '3.1.1.901', - 'origin': '1.2.0'}) + # Create filters with special versioning requirements. + # Treat all Origin 1.x as special case. + legacy_filters = [{'name': 'oo_version_gte_3_1_or_1_1', + 'versions': {'enterprise': '3.0.2.905', + 'origin': '1.1.0'}}, + {'name': 'oo_version_gte_3_1_1_or_1_1_1', + 'versions': {'enterprise': '3.1.1', + 'origin': '1.1.1'}}, + {'name': 'oo_version_gte_3_2_or_1_2', + 'versions': {'enterprise': '3.1.1.901', + 'origin': '1.2.0'}}, + {'name': 'oo_version_gte_3_3_or_1_3', + 'versions': {'enterprise': '3.3.0', + 'origin': '1.3.0'}}, + {'name': 'oo_version_gte_3_4_or_1_4', + 'versions': {'enterprise': '3.4.0', + 'origin': '1.4.0'}}, + {'name': 'oo_version_gte_3_5_or_1_5', + 'versions': {'enterprise': '3.5.0', + 'origin': '1.5.0'}}] + for legacy_filter in legacy_filters: + self._filters[legacy_filter['name']] = legacy_gte_function_builder(legacy_filter['name'], + legacy_filter['versions']) def filters(self): """ diff --git a/test/openshift_version_tests.py b/test/openshift_version_tests.py new file mode 100644 index 000000000..52e9a9888 --- /dev/null +++ b/test/openshift_version_tests.py @@ -0,0 +1,72 @@ +""" Tests for the openshift_version Ansible filter module. """ +# pylint: disable=missing-docstring,invalid-name + +import os +import sys +import unittest + +sys.path = [os.path.abspath(os.path.dirname(__file__) + "/../filter_plugins/")] + sys.path + +# pylint: disable=import-error +import openshift_version # noqa: E402 + + +class OpenShiftVersionTests(unittest.TestCase): + + openshift_version_filters = openshift_version.FilterModule() + + # Static tests for legacy filters. + legacy_gte_tests = [{'name': 'oo_version_gte_3_1_or_1_1', + 'positive_enterprise_version': '3.2.0', + 'negative_enterprise_version': '3.0.0', + 'positive_origin_version': '1.2.0', + 'negative_origin_version': '1.0.0'}, + {'name': 'oo_version_gte_3_1_1_or_1_1_1', + 'positive_enterprise_version': '3.2.0', + 'negative_enterprise_version': '3.1.0', + 'positive_origin_version': '1.2.0', + 'negative_origin_version': '1.1.0'}, + {'name': 'oo_version_gte_3_2_or_1_2', + 'positive_enterprise_version': '3.3.0', + 'negative_enterprise_version': '3.1.0', + 'positive_origin_version': '1.3.0', + 'negative_origin_version': '1.1.0'}, + {'name': 'oo_version_gte_3_3_or_1_3', + 'positive_enterprise_version': '3.4.0', + 'negative_enterprise_version': '3.2.0', + 'positive_origin_version': '1.4.0', + 'negative_origin_version': '1.2.0'}, + {'name': 'oo_version_gte_3_4_or_1_4', + 'positive_enterprise_version': '3.5.0', + 'negative_enterprise_version': '3.3.0', + 'positive_origin_version': '1.5.0', + 'negative_origin_version': '1.3.0'}, + {'name': 'oo_version_gte_3_5_or_1_5', + 'positive_enterprise_version': '3.6.0', + 'negative_enterprise_version': '3.4.0', + 'positive_origin_version': '1.6.0', + 'negative_origin_version': '1.4.0'}] + + def test_legacy_gte_filters(self): + for test in self.legacy_gte_tests: + for deployment_type in ['enterprise', 'origin']: + # Test negative case per deployment_type + self.assertFalse( + self.openshift_version_filters._filters[test['name']]( + test["negative_{}_version".format(deployment_type)], deployment_type)) + # Test positive case per deployment_type + self.assertTrue( + self.openshift_version_filters._filters[test['name']]( + test["positive_{}_version".format(deployment_type)], deployment_type)) + + def test_gte_filters(self): + for major, minor_start, minor_end in self.openshift_version_filters.versions: + for minor in range(minor_start, minor_end): + # Test positive case + self.assertTrue( + self.openshift_version_filters._filters["oo_version_gte_{}_{}".format(major, minor)]( + "{}.{}".format(major, minor + 1))) + # Test negative case + self.assertFalse( + self.openshift_version_filters._filters["oo_version_gte_{}_{}".format(major, minor)]( + "{}.{}".format(major, minor))) -- cgit v1.2.3