[ 
https://issues.apache.org/jira/browse/GOBBLIN-2110?focusedWorklogId=926213&page=com.atlassian.jira.plugin.system.issuetabpanels:worklog-tabpanel#worklog-926213
 ]

ASF GitHub Bot logged work on GOBBLIN-2110:
-------------------------------------------

                Author: ASF GitHub Bot
            Created on: 16/Jul/24 19:34
            Start Date: 16/Jul/24 19:34
    Worklog Time Spent: 10m 
      Work Description: arjun4084346 commented on code in PR #4001:
URL: https://github.com/apache/gobblin/pull/4001#discussion_r1679974324


##########
gobblin-utility/src/main/java/org/apache/gobblin/util/retry/RetryerFactory.java:
##########
@@ -104,32 +117,75 @@ public static <T> Retryer<T> newInstance(Config config, 
Optional<RetryListener>
     return builder.build();
   }
 
+  /**
+   Retrieves a retry predicate based on the configuration provided. If the 
configuration
+   does not specify any exceptions, a default retry predicate is returned.
+   *
+   @param config the configuration object containing the list of exception 
class names
+   @return a Predicate that evaluates to true if the throwable should be 
retried, false otherwise
+   */
+  @VisibleForTesting
+  public static Predicate<Throwable> 
getRetryPredicateFromConfigOrDefault(Config config) {
+    // Retrieve the list of exception class names from the configuration
+    List<String> exceptionList = ConfigUtils.getStringList(config, 
EXCEPTION_LIST_FOR_RETRY_CONFIG_KEY);
+
+    // If the exception list is null or empty, return the default retry 
predicate
+    if (exceptionList == null || exceptionList.isEmpty()) {

Review Comment:
   in this case, actually lets create a method `List<String> 
getStringList(Config config, String path, List<String> def)` (taking idea from 
the similar methods to get Int, String or other types) and then
   
   `return ConfigUtils.getStringList(config, 
EXCEPTION_LIST_FOR_RETRY_CONFIG_KEY, RETRY_EXCEPTION_PREDICATE_DEFAULT);`





Issue Time Tracking
-------------------

    Worklog Id:     (was: 926213)
    Time Spent: 50m  (was: 40m)

> Make retry_exception_predicate configurable in RetryerFactory
> -------------------------------------------------------------
>
>                 Key: GOBBLIN-2110
>                 URL: https://issues.apache.org/jira/browse/GOBBLIN-2110
>             Project: Apache Gobblin
>          Issue Type: Bug
>            Reporter: Aditya Pratap Singh
>            Priority: Minor
>          Time Spent: 50m
>  Remaining Estimate: 0h
>
> Make retry_exception_predicate configurable in RetryerFactory



--
This message was sent by Atlassian Jira
(v8.20.10#820010)

Reply via email to