-
Notifications
You must be signed in to change notification settings - Fork 3.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
colexecerror: improve the panic-catcher
This commit updates the vectorized panic-catcher to not catch panics if they came from the catcher itself. Previously, this would occur when we have several levels of catchers with the inner-most determining that the panic is not from the vectorized engine. This would result in `panic(panicObj)` call, however, the catcher one level up would see that the panic came from `CatchVectorizedRuntimeError` which is "within" the vectorized engine, thus, the higher level catcher could do something with it while it shouldn't. This commit also starts treating packages with `pkg/sql/row` in the path prefix (e.g. `rowexec`, `row`, `rowenc`) as part of the vectorized engine too (previously, only `rowexec` was treated as such). Additionally, this commit adds a utility method `NonVectorizedTestPanic` that can be used by the testing code to simulate panics that occur outside of the vectorized engine. Release note: None
- Loading branch information
1 parent
0e98670
commit 4cbe229
Showing
5 changed files
with
118 additions
and
17 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
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,76 @@ | ||
// Copyright 2021 The Cockroach Authors. | ||
// | ||
// Use of this software is governed by the Business Source License | ||
// included in the file licenses/BSL.txt. | ||
// | ||
// As of the Change Date specified in that file, in accordance with | ||
// the Business Source License, use of this software will be governed | ||
// by the Apache License, Version 2.0, included in the file | ||
// licenses/APL.txt. | ||
|
||
package colexecerror_test | ||
|
||
import ( | ||
"errors" | ||
"strings" | ||
"testing" | ||
|
||
"github.com/cockroachdb/cockroach/pkg/sql/colexecbase/colexecerror" | ||
"github.com/cockroachdb/cockroach/pkg/util/leaktest" | ||
"github.com/cockroachdb/cockroach/pkg/util/log" | ||
"github.com/stretchr/testify/require" | ||
) | ||
|
||
// TestCatchVectorizedRuntimeError verifies that the panic-catcher doesn't catch | ||
// panics that originate outside of the vectorized engine and correctly | ||
// annotates errors that are propagated via | ||
// colexecerror.(Internal|Expected)Error methods. | ||
func TestCatchVectorizedRuntimeError(t *testing.T) { | ||
defer leaktest.AfterTest(t)() | ||
defer log.Scope(t).Close(t) | ||
|
||
// Setup multiple levels of catchers to ensure that the panic-catcher | ||
// doesn't fool itself into catching panics that the inner catcher emitted. | ||
require.Panics(t, func() { | ||
require.NoError(t, colexecerror.CatchVectorizedRuntimeError(func() { | ||
require.NoError(t, colexecerror.CatchVectorizedRuntimeError(func() { | ||
colexecerror.NonVectorizedTestPanic(errors.New("should not be caught")) | ||
})) | ||
})) | ||
}) | ||
|
||
const shouldBeCaughtText = "should be caught" | ||
shouldBeCaughtErr := errors.New(shouldBeCaughtText) | ||
const annotationText = "unexpected error from the vectorized engine" | ||
|
||
// Propagate an error as an internal one (this should add annotations to the | ||
// returned error). | ||
annotatedErr := colexecerror.CatchVectorizedRuntimeError(func() { | ||
colexecerror.InternalError(shouldBeCaughtErr) | ||
}) | ||
require.NotNil(t, annotatedErr) | ||
require.True(t, strings.Contains(annotatedErr.Error(), shouldBeCaughtText)) | ||
require.True(t, strings.Contains(annotatedErr.Error(), annotationText)) | ||
|
||
// Propagate an error as an expected one (this should *not* add annotations | ||
// to the returned error). | ||
notAnnotatedErr := colexecerror.CatchVectorizedRuntimeError(func() { | ||
colexecerror.ExpectedError(shouldBeCaughtErr) | ||
}) | ||
require.NotNil(t, notAnnotatedErr) | ||
require.True(t, strings.Contains(notAnnotatedErr.Error(), shouldBeCaughtText)) | ||
require.False(t, strings.Contains(notAnnotatedErr.Error(), annotationText)) | ||
} | ||
|
||
// TestNonVectorizedTestPanicIsNotCaught verifies that panics emitted via | ||
// NonVectorizedTestPanic() method are not caught by the catcher. | ||
func TestNonVectorizedTestPanicIsNotCaught(t *testing.T) { | ||
defer leaktest.AfterTest(t)() | ||
defer log.Scope(t).Close(t) | ||
|
||
require.Panics(t, func() { | ||
require.NoError(t, colexecerror.CatchVectorizedRuntimeError(func() { | ||
colexecerror.NonVectorizedTestPanic("should panic") | ||
})) | ||
}) | ||
} |
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