Skip to content

Commit

Permalink
return a wrapped error
Browse files Browse the repository at this point in the history
  • Loading branch information
qingyang-hu committed Dec 5, 2024
1 parent 701bd46 commit 614aba5
Show file tree
Hide file tree
Showing 4 changed files with 11 additions and 12 deletions.
5 changes: 2 additions & 3 deletions internal/integration/client_side_encryption_prose_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -3111,7 +3111,7 @@ func TestClientSideEncryptionProse(t *testing.T) {

ceo := options.ClientEncryption().
SetKeyVaultNamespace(kvNamespace).
SetKmsProviders(fullKmsProvidersMap).
SetKmsProviders(kmsProviders).
SetTLSConfig(map[string]*tls.Config{dataKey.provider: tlsCfg})
clientEncryption, err := mongo.NewClientEncryption(keyVaultClient, ceo)
require.NoError(mt, err, "error on NewClientEncryption: %v", err)
Expand All @@ -3121,8 +3121,7 @@ func TestClientSideEncryptionProse(t *testing.T) {

dkOpts := options.DataKey().SetMasterKey(dataKey.masterKey)
_, err = clientEncryption.CreateDataKey(context.Background(), dataKey.provider, dkOpts)
require.Error(mt, err)
mt.Logf("CreateDataKey error: %v", err)
require.ErrorContains(mt, err, "KMS request failed after 3 retries due to a network error")
})
}
})
Expand Down
5 changes: 1 addition & 4 deletions x/mongo/driver/crypt.go
Original file line number Diff line number Diff line change
Expand Up @@ -398,10 +398,7 @@ func (c *crypt) decryptKey(kmsCtx *mongocrypt.KmsContext) error {
res := make([]byte, bytesNeeded)
bytesRead, err := conn.Read(res)
if err != nil {
if kmsCtx.Fail() {
err = nil
}
return err
return kmsCtx.RequestError()
}

if err = kmsCtx.FeedResponse(res[:bytesRead]); err != nil {
Expand Down
9 changes: 6 additions & 3 deletions x/mongo/driver/mongocrypt/mongocrypt_kms_context.go
Original file line number Diff line number Diff line change
Expand Up @@ -78,7 +78,10 @@ func (kc *KmsContext) createErrorFromStatus() error {
return errorFromStatus(status)
}

// Fail returns a boolean indicating whether the failed request may be retried.
func (kc *KmsContext) Fail() bool {
return bool(C.mongocrypt_kms_ctx_fail(kc.wrapped))
// RequestError returns the source of the network error for KMS requests.
func (kc *KmsContext) RequestError() error {
if bool(C.mongocrypt_kms_ctx_fail(kc.wrapped)) {
return nil
}
return kc.createErrorFromStatus()
}
Original file line number Diff line number Diff line change
Expand Up @@ -38,7 +38,7 @@ func (kc *KmsContext) FeedResponse([]byte) error {
panic(cseNotSupportedMsg)
}

// Fail returns a boolean indicating whether the failed request may be retried.
func (kc *KmsContext) Fail() bool {
// RequestError returns the source of the network error for KMS requests.
func (kc *KmsContext) RequestError() error {
panic(cseNotSupportedMsg)
}

0 comments on commit 614aba5

Please sign in to comment.