Stamatis Zampetakis created HIVE-23946: ------------------------------------------
Summary: Improve control flow and error handling in QTest dataset loading/unloading Key: HIVE-23946 URL: https://issues.apache.org/jira/browse/HIVE-23946 Project: Hive Issue Type: Improvement Reporter: Stamatis Zampetakis Assignee: Stamatis Zampetakis This issue focuses mainly on the following methods: [QTestDatasetHandler#initDataset| https://github.com/apache/hive/blob/6fbd54c0af60276d49b237defb550938c9c32610/itests/util/src/main/java/org/apache/hadoop/hive/ql/dataset/QTestDatasetHandler.java#L76] [QTestDatasetHandler#unloadDataset|https://github.com/apache/hive/blob/6fbd54c0af60276d49b237defb550938c9c32610/itests/util/src/main/java/org/apache/hadoop/hive/ql/dataset/QTestDatasetHandler.java#L95] related to QTest dataset loading and unloading. The boolean return type in these methods is redundant since they either fail or return true (they never return false). The methods should throw an Exception instead of an AssertionError to indicate failure. This allows code higher up the stack to perform proper recovery and properly report the failure. At the moment, if an AssertionError is raised from these methods dependent code (eg., [CoreCliDriver|https://github.com/apache/hive/blob/6fbd54c0af60276d49b237defb550938c9c32610/itests/util/src/main/java/org/apache/hadoop/hive/cli/control/CoreCliDriver.java#L188]) fails to notice that the query has failed. In case of failure in loading/unloading the environment (instance and class variables) is not properly cleaned leading to failures in all subsequent tests. -- This message was sent by Atlassian Jira (v8.3.4#803005)