v4.13.17 - Overhauled JavaScript stack trace parsing #732
jongpie
announced in
Announcements
Replies: 0 comments
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
-
The changes in this release should not change anything about how you use Nebula Logger for JavaScript (JS) logging in lightning web components (LWCs) and Aura components - but the overall approach used internally by Nebula Logger for parsing JavaScript stack traces has been completely redesigned.
Previously, Apex code was used to parse JS stack traces (using the Apex classes
LoggerStackTrace
andComponentLogger
). But now, JS parsing occurs directly in JS, which provides several benefits:logger
LWC is leveraged, and in which of the availabletargets
is used for your own LWCs/Aura components (which then call thelogger
LWC). This release should fix most of these issues.stacktrace.js
is now used to handle the majority of JS stack trace parsing, instead of trying to write code from scratch to handle parsing.console
logging statements in the browser's console: with a parsed version of the JS stack trace now available directly in JS, thelogger
LWC can now provide better context to JS developers trying to see the output ofconsole
statements when troubleshooting & debugging LWCs and Aura components.Many thanks to @ZackFra for identifying the critical problems in the previous code & some approaches to use to resolve them (see PR #692). These contributions have led to identifying even more issues with the old approach that were previously unreported, and helped solidify the decision to migrate from Apex to JS for parsing JS stack traces.
And thanks to @jamessimone as well for all of his helping with questions & thoughts during the dev work, input on improving
console
logging statements, and code reviewing PR #692.For a more details about the issues found & what's changed, see:
Core Unlocked Package Changes
logger
LWC to leverage the open source library JavaScript librarystacktrace.js
to parse stack tracesLoggerStackTrace
andComponentLogger
that previously handled JS stack traces. There are still a few lingering items (enums, method overloads, etc.) that are now deprecated & will be removed in a future releaseloggerStackTrace.js
to thelogger
LWC - the file contains a modified version of the parsing code fromstacktrace.js
, as well as a few additional pieces of logic to improve parsing of Salesforce-specific stack tracesconsole
logging statements. Each JS logging statement now includes a pretty-printed JSON string that has the most relevant info about the log entry's origin, including the timestamp of the log entry, the component name, function name, and the component metadata typeConsole output in Chrome:
Console output in Firefox:
Console output in Microsoft Edge:
Recipes Metadata Changes
It took a lot of effort to even be able to test some of these issues, as Nebula Logger's repo previously didn't have sample metadata setup for most of the
targets
available for lightning components. This release includes several changes to make it easier to test logging in different targets in a scratch org, using multiple browsers. These changes are not included in Nebula Logger directly, but they help during development & testing. The changes include:recipes
metadata so that the 3 demo components (listed below) can now be easily tested in multiple contexts, using theLogger Recipes
app<c:loggerAuraEmbedDemo>
Aura component<c-loggerLWCEmbedDemo>
LWC<c-loggerLWCImportDemo>
LWCconfig
(used by the pipeline & during development)Now, the recipes app is setup to quickly test the 3 demo components in multiple
targets
Installation Info
Core Unlocked Package - no namespace
Full Changelog: v4.13.16...v4.13.17
sf package install --wait 20 --security-type AdminsOnly --package 04t5Y0000015oPCQAY
sfdx force:package:install --wait 20 --securitytype AdminsOnly --package 04t5Y0000015oPCQAY
This discussion was created from the release Overhauled JavaScript stack trace parsing.
Beta Was this translation helpful? Give feedback.
All reactions