mirror of
https://github.com/apache/impala.git
synced 2025-12-19 18:12:08 -05:00
IMPALA-11977: Fix Python 3 broken imports and object model differences
Python 3 changed some object model methods: - __nonzero__ was removed in favor of __bool__ - func_dict / func_name were removed in favor of __dict__ / __name__ - The next() function was deprecated in favor of __next__ (Code locations should use next(iter) rather than iter.next()) - metaclasses are specified a different way - Locations that specify __eq__ should also specify __hash__ Python 3 also moved some packages around (urllib2, Queue, httplib, etc), and this adapts the code to use the new locations (usually handled on Python 2 via future). This also fixes the code to avoid referencing exception variables outside the exception block and variables outside of a comprehension. Several of these seem like false positives, but it is better to avoid the warning. This fixes these pylint warnings: bad-python3-import eq-without-hash metaclass-assignment next-method-called nonzero-method exception-escape comprehension-escape Testing: - Ran core tests - Ran release exhaustive tests Change-Id: I988ae6c139142678b0d40f1f4170b892eabf25ee Reviewed-on: http://gerrit.cloudera.org:8080/19592 Reviewed-by: Joe McDonnell <joemcdonnell@cloudera.com> Tested-by: Impala Public Jenkins <impala-public-jenkins@cloudera.com>
This commit is contained in:
@@ -44,10 +44,10 @@ class TestExecutorGroups(CustomClusterTestSuite):
|
||||
|
||||
def setup_method(self, method):
|
||||
# Always start the base cluster with the coordinator in its own executor group.
|
||||
existing_args = method.func_dict.get("impalad_args", "")
|
||||
method.func_dict["impalad_args"] = "%s -executor_groups=coordinator" % existing_args
|
||||
method.func_dict["cluster_size"] = 1
|
||||
method.func_dict["num_exclusive_coordinators"] = 1
|
||||
existing_args = method.__dict__.get("impalad_args", "")
|
||||
method.__dict__["impalad_args"] = "%s -executor_groups=coordinator" % existing_args
|
||||
method.__dict__["cluster_size"] = 1
|
||||
method.__dict__["num_exclusive_coordinators"] = 1
|
||||
self.num_groups = 1
|
||||
self.num_impalads = 1
|
||||
super(TestExecutorGroups, self).setup_method(method)
|
||||
|
||||
Reference in New Issue
Block a user