summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJenkins <jenkins@review.openstack.org>2012-12-05 21:16:32 +0000
committerGerrit Code Review <review@openstack.org>2012-12-05 21:16:32 +0000
commitea7ced276d2f080718cd89f3a77378cdf24fabf5 (patch)
tree8af04e6b8fb4a8fe952df20ab4dd0fa25a0454ae
parent2f7a7edc41d0e7b663877592aeda14e766a64241 (diff)
parentc67f2881a4bbe5958048610458180c3f9d914964 (diff)
downloadoslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.tar.gz
oslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.tar.xz
oslo-ea7ced276d2f080718cd89f3a77378cdf24fabf5.zip
Merge "Fix broken --version command"
-rw-r--r--openstack/common/version.py32
-rw-r--r--tests/unit/test_version.py68
2 files changed, 94 insertions, 6 deletions
diff --git a/openstack/common/version.py b/openstack/common/version.py
index a19e422..dae88e3 100644
--- a/openstack/common/version.py
+++ b/openstack/common/version.py
@@ -24,17 +24,37 @@ import pkg_resources
import setup
-class _deferred_version_string(object):
+class _deferred_version_string(str):
"""Internal helper class which provides delayed version calculation."""
- def __init__(self, version_info, prefix):
- self.version_info = version_info
- self.prefix = prefix
+
+ def __new__(cls, version_info, prefix):
+ new_obj = str.__new__(cls, "")
+ new_obj._version_info = version_info
+ new_obj._prefix = prefix
+ new_obj._cached_version = None
+ return new_obj
+
+ def _get_cached_version(self):
+ if not self._cached_version:
+ self._cached_version = \
+ "%s%s" % (self._prefix,
+ self._version_info.version_string())
+ return self._cached_version
+
+ def __len__(self):
+ return self._get_cached_version().__len__()
+
+ def __contains__(self, item):
+ return self._get_cached_version().__contains__(item)
+
+ def __getslice__(self, i, j):
+ return self._get_cached_version().__getslice__(i, j)
def __str__(self):
- return "%s%s" % (self.prefix, self.version_info.version_string())
+ return self._get_cached_version()
def __repr__(self):
- return "%s%s" % (self.prefix, self.version_info.version_string())
+ return self._get_cached_version()
class VersionInfo(object):
diff --git a/tests/unit/test_version.py b/tests/unit/test_version.py
new file mode 100644
index 0000000..8e60f51
--- /dev/null
+++ b/tests/unit/test_version.py
@@ -0,0 +1,68 @@
+# vim: tabstop=4 shiftwidth=4 softtabstop=4
+
+# Copyright 2012 Red Hat, Inc.
+#
+# 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.
+
+import os
+import shutil
+import sys
+import StringIO
+import tempfile
+import unittest
+
+import stubout
+
+from openstack.common.cfg import *
+from openstack.common import version
+
+
+class BaseTestCase(unittest.TestCase):
+
+ def setUp(self):
+ self.stubs = stubout.StubOutForTesting()
+
+ def tearDown(self):
+ self.stubs.UnsetAll()
+
+
+class DeferredVersionTestCase(BaseTestCase):
+
+ def setUp(self):
+ super(DeferredVersionTestCase, self).setUp()
+ self.conf = ConfigOpts()
+
+ def test_deferred_version(self):
+ class MyVersionInfo(version.VersionInfo):
+ def _generate_version(self):
+ return "5.5.5.5"
+
+ deferred_string = MyVersionInfo("openstack").\
+ deferred_version_string()
+ self.conf([], project="project", prog="prog", version=deferred_string)
+ self.assertEquals("5.5.5.5", str(self.conf.version))
+
+ def test_print_deferred_version(self):
+ class MyVersionInfo(version.VersionInfo):
+ def _generate_version(self):
+ return "5.5.5.5"
+
+ deferred_string = MyVersionInfo("openstack")\
+ .deferred_version_string()
+ self.stubs.Set(sys, 'stderr', StringIO.StringIO())
+ self.assertRaises(SystemExit,
+ self.conf, ['--version'],
+ project="project",
+ prog="prog",
+ version=deferred_string)
+ self.assertEquals("5.5.5.5", sys.stderr.getvalue().strip())