Galen O'Sullivan created GEODE-2375: ---------------------------------------
Summary: GemFireException should not inherit from RuntimeException Key: GEODE-2375 URL: https://issues.apache.org/jira/browse/GEODE-2375 Project: Geode Issue Type: Bug Components: core, general Reporter: Galen O'Sullivan {{GemFireException}} inherits from {{RuntimeException}}, which means that the majority of exceptions in Geode are unchecked. This means that we don't have the type system helping us to check potential failure conditions of our code, and it's not clear which functions may throw exceptions as a part of their nomal failure modes -- for example, {{ReplyException}} has a {{handleAsUnexpected}} method that seems to indicate that a normal {{ReplyException}} is not unexpected -- but that's not what the type inheritance says. {{GemFireException}} accounts for most of the exceptions in the codebase. Even if we were to convert most of the existing instances of {{GemFireException}} to {{GemFireRuntimeException}}, developers (especially new ones) would still be tempted to use {{GemFireException}} for new exceptions. Perhaps the best way to solve this (if we want all our exceptions to inherit from a central exception type, which I'm not entirely sold on) would be to create a new {{GeodeUncheckedException}} and {{GeodeCheckedException}}, and deprecate both kinds of {{GemFireException}}? Then we could convert old exceptions as time permits. There's a significant amount of work involved here whatever way we decide to change it. -- This message was sent by Atlassian JIRA (v6.3.4#6332)