From 6bd802912df4f02738b6e5249e3edcf57ce8684f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?G=C3=A1bor=20Antal?= Date: Tue, 13 Sep 2016 11:36:55 +0200 Subject: [PATCH] Switching expression order within if condition In nova/cmd/manage.py, on line 294 [1] there is the following line: if value['limit'] < 0 or value['limit'] is None: The problem occurs when value['limit'] is None, as this line tries to compare None (object) with an integer value. This comparsion is totally okay (without errors) in Python27. But, if you run this on Python34, a TypError is raised: TypeError: unorderable types: NoneType() < int() It is simply fixed with swapping the two expressions within the if condition. Now if value['limit'] is None, the first expression becomes true and second one does not get evaluated. TrivialFix [1]: https://github.com/openstack/nova/blob/master/nova/cmd/manage.py#L294 Change-Id: Id2b1ed67e1c2c9f1d1aa5a23740db2b18e2e7141 --- nova/cmd/manage.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/nova/cmd/manage.py b/nova/cmd/manage.py index 96954f73fbd6..a9a04f1e8358 100644 --- a/nova/cmd/manage.py +++ b/nova/cmd/manage.py @@ -291,7 +291,7 @@ class ProjectCommands(object): else: quota = QUOTAS.get_project_quotas(ctxt, project_id) for key, value in six.iteritems(quota): - if value['limit'] < 0 or value['limit'] is None: + if value['limit'] is None or value['limit'] < 0: value['limit'] = 'unlimited' print(print_format % (key, value['limit'], value['in_use'], value['reserved']))