-
Notifications
You must be signed in to change notification settings - Fork 1.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
js: Print stack trace when exception in handleSummary() #3416
Conversation
js/runner.go
Outdated
if handleSummaryFn, ok := goja.AssertFunction(fn); ok { | ||
callbackResult, _, _, err = vu.runFn(summaryCtx, false, handleSummaryFn, nil, vu.Runtime.ToValue(summaryDataForJS)) | ||
if err != nil { | ||
errext.Fprint(r.preInitState.Logger, err) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Alternatively to what I suggested at https://github.com/grafana/k6/pull/3416/files#r1370043306, I could add another log line here, giving that feedback to the user in a different line (and maybe as debug
?).
Codecov ReportAll modified and coverable lines are covered by tests ✅
Additional details and impacted files@@ Coverage Diff @@
## master #3416 +/- ##
=======================================
Coverage 73.34% 73.34%
=======================================
Files 258 259 +1
Lines 19645 19653 +8
=======================================
+ Hits 14408 14415 +7
Misses 4352 4352
- Partials 885 886 +1
Flags with carried forward coverage won't be shown. Click here to find out more.
☔ View full report in Codecov by Sentry. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM in general 👏
Can we maybe try option 2 from https://github.com/grafana/k6/pull/3416/files#r1370141890
That is true, but maybe we can extend Line 669 in 036f8a0
|
Changed, as per what discussed "offline", thanks! |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM 👍🏻 👏🏻 Great job @joanlopez 🙇🏻
Co-authored-by: Mihail Stoykov <[email protected]>
What?
It splits the execution of the
handleSummary()
wrapper, so if there's an exception on the script, it prints the stack trace first, then falls back to the default summary.It also moves the logic to print
errext.HasHint
anderrext.Exception
details for a given error into a shared function within theerrext
package, following "the fprint pattern" (that accepts a "writer", in this case a "logger"), so it can be reused where it was used until now (rootCommand
) and in the aforementioned exception handling.Why?
Currently, exceptions in
handleSummary()
do not print stack, just a message that there was an exception, and that makes debugging it way harder than it should.Checklist
make lint
) and all checks pass.make tests
) and all tests pass.Related PR(s)/Issue(s)
Closes #3257
Other notes
I haven't added any new test because if I'm not wrong, I think all the logic changed is already covered by tests present in
summary_test.go
, likeTestExceptionInHandleSummaryFallsBackToTextSummary
that precisely asserts that the default summary is used as summary when thehandleSummary()
throws an exception.In fact, if I'm not wrong, the main behavior should not change, it's just a matter of bringing feedback to the user (logs) in a slightly different way (more clear/explicit).
Thanks!