From 1bb492eaf4fa078709f7f6cef51b28489097e8cf Mon Sep 17 00:00:00 2001 From: Andrey Kurilin Date: Tue, 22 May 2018 13:55:12 +0300 Subject: [PATCH] Add a reminder for compatibility workarounds rally-openstack package should not be aligned to one constant version of Rally framework. It means that some workarounds for compatibility stuff are provided. The new test raises an error if with bumping a minimum required version nothing is changed, i.e. no one is removed outdated code. Change-Id: I0eef307677ba15c037b5013d170df608dfd04017 --- tests/unit/test_workarounds.py | 60 ++++++++++++++++++++++++++++++++++ 1 file changed, 60 insertions(+) create mode 100644 tests/unit/test_workarounds.py diff --git a/tests/unit/test_workarounds.py b/tests/unit/test_workarounds.py new file mode 100644 index 00000000..a96e6cca --- /dev/null +++ b/tests/unit/test_workarounds.py @@ -0,0 +1,60 @@ +# All Rights Reserved. +# +# 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. + +""" +rally-openstack package should not be aligned to one constant version of Rally +framework. It means that some workarounds for compatibility stuff are +provided. +This module should contain historical notes and checks to do not forget remove +these workaround. +""" + +import pkg_resources + +from tests.unit import test + + +class WorkaroundTestCase(test.TestCase): + WORKAROUNDS = [ + ([0, 12], [ + "'rally_openstack.__init__' module contains a hack for loading " + "configuration options.", + "'rally_openstack.types' module contains a compatibility layer for" + " an old interface of ResourceTypes."] + ) + ] + + def get_min_required_version(self): + package = pkg_resources.get_distribution("rally-openstack") + requirement = [p for p in package.requires() if p.name == "rally"][0] + + for statement, version in requirement.specs: + version = [int(i) for i in version.split(".")] + if statement == ">=": + return version + elif statement == ">": + version[-1] += 1 + return version + self.skip("Failed to get a minimum required version of Rally " + "framework.") + + def test_rally_version(self): + rally_version = self.get_min_required_version() + + for version, workarounds in self.WORKAROUNDS: + if rally_version >= version: + self.fail( + "After bumping minimum required version of Rally, some " + "workarounds become redundant. See the following list and " + "update the code: \n\t%s" % "\n\t".join(workarounds))