Skip to content

Commit 0f0c853

Browse files
authored
convert panic when it is not error (#2486)
1 parent ff18623 commit 0f0c853

File tree

2 files changed

+56
-5
lines changed

2 files changed

+56
-5
lines changed

common/log/panic.go

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -33,17 +33,15 @@ import (
3333
"go.temporal.io/server/common/log/tag"
3434
)
3535

36-
var errDefaultPanic = fmt.Errorf("panic object is not error")
37-
3836
// CapturePanic is used to capture panic, it will log the panic and also return the error through pointer.
3937
// If the panic value is not error then a default error is returned
4038
// We have to use pointer is because in golang: "recover return nil if was not called directly by a deferred function."
4139
// And we have to set the returned error otherwise our handler will return nil as error which is incorrect
4240
func CapturePanic(logger Logger, retError *error) {
43-
if errPanic := recover(); errPanic != nil {
44-
err, ok := errPanic.(error)
41+
if panicObj := recover(); panicObj != nil {
42+
err, ok := panicObj.(error)
4543
if !ok {
46-
err = errDefaultPanic
44+
err = fmt.Errorf("panic: %v", panicObj)
4745
}
4846

4947
st := string(debug.Stack())

common/log/panic_test.go

Lines changed: 53 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,53 @@
1+
// The MIT License
2+
//
3+
// Copyright (c) 2020 Temporal Technologies Inc. All rights reserved.
4+
//
5+
// Copyright (c) 2020 Uber Technologies, Inc.
6+
//
7+
// Permission is hereby granted, free of charge, to any person obtaining a copy
8+
// of this software and associated documentation files (the "Software"), to deal
9+
// in the Software without restriction, including without limitation the rights
10+
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11+
// copies of the Software, and to permit persons to whom the Software is
12+
// furnished to do so, subject to the following conditions:
13+
//
14+
// The above copyright notice and this permission notice shall be included in
15+
// all copies or substantial portions of the Software.
16+
//
17+
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18+
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19+
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20+
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21+
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22+
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23+
// THE SOFTWARE.
24+
25+
package log
26+
27+
import (
28+
"fmt"
29+
"testing"
30+
31+
"github.com/stretchr/testify/assert"
32+
)
33+
34+
func TestCapturePanic(t *testing.T) {
35+
fooErr := testCapture("foo")
36+
assert.Error(t, fooErr)
37+
assert.Equal(t, "panic: foo", fooErr.Error())
38+
39+
barErr := testCapture(fmt.Errorf("error: %v", "bar"))
40+
assert.Error(t, barErr)
41+
assert.Equal(t, "error: bar", barErr.Error())
42+
}
43+
44+
func testCapture(panicObj interface{}) (retErr error) {
45+
defer CapturePanic(NewNoopLogger(), &retErr)
46+
47+
testPanic(panicObj)
48+
return nil
49+
}
50+
51+
func testPanic(panicObj interface{}) {
52+
panic(panicObj)
53+
}

0 commit comments

Comments
 (0)