forked from databricks/databricks-sdk-java
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Override INVALID_PARAMETER_VALUE on fetching non-existent job/cluster (…
…databricks#257) ## Changes Ports databricks/databricks-sdk-go#864 to the Java SDK. Most services use `RESOURCE_DOES_NOT_EXIST` error code with 404 status code to indicate that a resource doesn't exist. However, for legacy reasons, Jobs and Clusters services use `INVALID_PARAMETER_VALUE` error code with 400 status code instead. This makes tools like Terraform and UCX difficult to maintain, as these services need different error handling logic. However, we can't change these behaviors as customers already depend on the raw HTTP response status & contents. This PR corrects these errors in the SDK itself. SDK users can then do ```java try { BaseJob job = w.jobs().get("123"); } catch (ResourceDoesNotExist e) { ... } ``` just as you would expect from other resources. Updated the README with more information about this as well. ## Tests Added unit tests for error overrides. Added/updated the integration tests for Clusters and Jobs. - [x] `make test` passing - [x] `make fmt` applied - [x] relevant integration tests applied
- Loading branch information
1 parent
972b304
commit 4ab4fd0
Showing
12 changed files
with
237 additions
and
6 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
// Code generated from OpenAPI specs by Databricks SDK Generator. DO NOT EDIT. | ||
|
||
package com.databricks.sdk.core.error; | ||
|
||
import java.util.Arrays; | ||
import java.util.List; | ||
|
||
import com.databricks.sdk.support.Generated; | ||
|
||
@Generated | ||
class ErrorOverrides { | ||
static final List<ErrorOverride<?>> ALL_OVERRIDES = Arrays.asList( | ||
{{- range $i, $x := .ErrorOverrides }} | ||
{{if not (eq $i 0)}}, {{end}}new ErrorOverride<>( | ||
"{{$x.Name}}", | ||
"{{ replaceAll "\\" "\\\\" $x.PathRegex}}", | ||
"{{$x.Verb}}", | ||
"{{ replaceAll "\\" "\\\\" $x.StatusCodeMatcher}}", | ||
"{{ replaceAll "\\" "\\\\" $x.ErrorCodeMatcher}}", | ||
"{{ replaceAll "\\" "\\\\" $x.MessageMatcher}}", | ||
com.databricks.sdk.core.error.platform.{{$x.OverrideErrorCode.PascalName}}.class) | ||
{{- end}} | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
90 changes: 90 additions & 0 deletions
90
databricks-sdk-java/src/main/java/com/databricks/sdk/core/error/ErrorOverride.java
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,90 @@ | ||
package com.databricks.sdk.core.error; | ||
|
||
import com.databricks.sdk.core.DatabricksError; | ||
import com.databricks.sdk.core.DatabricksException; | ||
import com.databricks.sdk.core.http.Response; | ||
import java.lang.reflect.Constructor; | ||
import java.util.List; | ||
import java.util.regex.Pattern; | ||
|
||
public class ErrorOverride<T extends DatabricksError> { | ||
private final String debugName; | ||
private final Pattern pathRegex; | ||
private final String verb; | ||
private final Pattern statusCodeMatcher; | ||
private final Pattern errorCodeMatcher; | ||
private final Pattern messageMatcher; | ||
private final Class<T> customError; | ||
|
||
public ErrorOverride( | ||
String debugName, | ||
String pathRegex, | ||
String verb, | ||
String statusCodeMatcher, | ||
String errorCodeMatcher, | ||
String messageMatcher, | ||
Class<T> customError) { | ||
this.debugName = debugName; | ||
this.pathRegex = ErrorOverride.compilePattern(pathRegex); | ||
this.verb = verb; | ||
this.statusCodeMatcher = ErrorOverride.compilePattern(statusCodeMatcher); | ||
this.errorCodeMatcher = ErrorOverride.compilePattern(errorCodeMatcher); | ||
this.messageMatcher = ErrorOverride.compilePattern(messageMatcher); | ||
this.customError = customError; | ||
} | ||
|
||
public boolean matches(ApiErrorBody body, Response resp) { | ||
if (!resp.getRequest().getMethod().equals(this.verb)) { | ||
return false; | ||
} | ||
|
||
if (this.pathRegex != null | ||
&& !this.pathRegex.matcher(resp.getRequest().getUri().getPath()).matches()) { | ||
return false; | ||
} | ||
String statusCode = Integer.toString(resp.getStatusCode()); | ||
if (this.statusCodeMatcher != null && !this.statusCodeMatcher.matcher(statusCode).matches()) { | ||
return false; | ||
} | ||
if (this.errorCodeMatcher != null | ||
&& !this.errorCodeMatcher.matcher(body.getErrorCode()).matches()) { | ||
return false; | ||
} | ||
// Allow matching substring of the error message. | ||
if (this.messageMatcher != null && !this.messageMatcher.matcher(body.getMessage()).find()) { | ||
return false; | ||
} | ||
return true; | ||
} | ||
|
||
public String getDebugName() { | ||
return this.debugName; | ||
} | ||
|
||
public T makeError(ApiErrorBody body) { | ||
Constructor<?>[] constructors = this.customError.getConstructors(); | ||
for (Constructor<?> constructor : constructors) { | ||
Class<?>[] parameterTypes = constructor.getParameterTypes(); | ||
// All errors have a 2-argument constructor for the message and the error body. | ||
if (parameterTypes.length == 2 | ||
&& parameterTypes[0].equals(String.class) | ||
&& parameterTypes[1].equals(List.class)) { | ||
try { | ||
return (T) constructor.newInstance(body.getMessage(), body.getErrorDetails()); | ||
} catch (Exception e) { | ||
throw new DatabricksException( | ||
"Error creating custom error for error type " + this.customError.getName(), e); | ||
} | ||
} | ||
} | ||
throw new DatabricksException( | ||
"No suitable constructor found for error type " + this.customError.getName()); | ||
} | ||
|
||
private static Pattern compilePattern(String pattern) { | ||
if (pattern == null || pattern.isEmpty()) { | ||
return null; | ||
} | ||
return Pattern.compile(pattern); | ||
} | ||
} |
29 changes: 29 additions & 0 deletions
29
databricks-sdk-java/src/main/java/com/databricks/sdk/core/error/ErrorOverrides.java
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
1 change: 1 addition & 0 deletions
1
databricks-sdk-java/src/main/java/com/databricks/sdk/service/sql/ChannelName.java
Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters