Skip to content

Commit

Permalink
Merge pull request newrelic#960 from nr-swilloughby/nil_panic
Browse files Browse the repository at this point in the history
Fix handling of panic(nil)
  • Loading branch information
nr-swilloughby authored Sep 5, 2024
2 parents 2c21c19 + 8645083 commit d95445c
Showing 1 changed file with 17 additions and 8 deletions.
25 changes: 17 additions & 8 deletions v3/newrelic/internal_txn.go
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ import (
"net/http"
"net/url"
"reflect"
"runtime"
"runtime/debug"
"sync"
"time"
Expand Down Expand Up @@ -445,11 +446,16 @@ func (thd *thread) End(recovered interface{}) error {

txn.finished = true

if nil != recovered {
e := txnErrorFromPanic(time.Now(), recovered)
e.Stack = getStackTrace()
thd.noticeErrorInternal(e, nil, false)
log.Println(string(debug.Stack()))
// It used to be the case that panic(nil) would cause recover() to return nil,
// which we test for here. However, that is no longer the case, hence the extra
// check at this point to stop panic(nil) from propagating here. (as of Go 1.21)
if recovered != nil {
if _, isNilPanic := recovered.(*runtime.PanicNilError); !isNilPanic {
e := txnErrorFromPanic(time.Now(), recovered)
e.Stack = getStackTrace()
thd.noticeErrorInternal(e, nil, false)
log.Println(string(debug.Stack()))
}
}

txn.markEnd(time.Now(), thd.thread)
Expand Down Expand Up @@ -542,9 +548,12 @@ func (thd *thread) End(recovered interface{}) error {
}

// Note that if a consumer uses `panic(nil)`, the panic will not
// propagate.
if nil != recovered {
panic(recovered)
// propagate. Update: well, not anymore. Go now returns an actual
// non-nil value in this case.
if recovered != nil {
if _, isNilPanic := recovered.(*runtime.PanicNilError); !isNilPanic {
panic(recovered)
}
}

return nil
Expand Down

0 comments on commit d95445c

Please sign in to comment.