Electron + Sentry: Monitoring your production app with sourcemaps
Requestly
Posted on August 16, 2020
What is Sentry?
Actual Meaning
A soldier stationed to keep guard or to control access to a place. 💂‍♂️
Technical Meaning
Self-hosted and cloud-based error monitoring that helps software teams discover, triage, and prioritize errors in real-time.
Why @sentry/electron?
@sentry/electron is the official Sentry SDK for Electron applications. It can capture JavaScript exceptions in the main process and renderers, as well as collect native crash reports (Minidumps).
How to add sentry to your electron app?
-
Create a new file
sentryInit.js
which initialize sentry for both main and renderer process usingwebpack.DefinePlugin
.
// sentryInit.js const { init } = (process.type === 'browser' ? require('@sentry/electron/dist/main') : require('@sentry/electron/dist/renderer')); init({dsn: '__DSN__'});
__DSN__
: Change DSN with your sentry DSN key for
the project.You can get your sentry DSN key for the project from
https://sentry.io/settings/<org-name>/projects/<app-name>/keys/
-
In your webpack config files for main and renderer process, add this plugin. with the following configuration.
plugins: [ // main process new webpack.DefinePlugin({ 'process.type': '"browser"' }), // renderer process new webpack.DefinePlugin({ 'process.type': '"renderer"' }), ]
This will
require('@sentry/electron/dist/main')
for main process andrequire('@sentry/electron/dist/renderer')
in case of renderer process so that sentry can be initialized. -
Finally, import
sentryInit.js
in your Main and Renderer Processes as early as possible.
// main.js import 'sentryInit.js'; // background.renderer.js import 'sentryInit.js';
-
[Optional] Test whether sentry is catching exceptions.
Add
unhandledException()
at the end of your main and renderer process.
That’s it. Now you will see issues coming in your sentry dashboard 🎉
Why we should add SourceMap to Sentry?
Your errors will start coming in you sentry but they are still unusable if you have minified your code. Your errors will look like this right now:
To see the line number of the actual code from where the error came, you need to upload sourcemaps to sentry. After that, you will be able to see the actual line no. of the errors
How to add SourceMap in your app?
To add sourcemaps to sentry, you can either use sentry-cli
or @sentry/webpack-plugin
. We will be using sentry-cli
. You can find more about sentry sourcemaps from here.
For sourcemaps to work on sentry, you need to upload sourcemaps as well as their minified files too (Also if your sourecemaps doesn’t contain sourcesContent for the source files, you need to upload them too).
Install
sentry-cli
. Follow the steps here to install sentry-cli.-
Upload sourcemaps.
$ sentry-cli releases files <release_name> upload-sourcemaps \ path/to/sourcemaps/and/min/files --url-prefix '/url-prefix'
Note: Don’t forget to add proper url-prefix for files uploaded using sentry-cli else they won’t work properly.
Eg. If stack traces show
app:///app/dist/background.min.js
, then you need to add url-prefix'~/app/dist'
while uploading the file background.min.js. -
Enjoy stack traces with original source code.
What we do at Requestly
Requestly lets you supercharge your web development by allowing you to setup redirects, modify headers, switch hosts, insert user scripts, cancel requests and much more.
We are in the process of building our desktop app which lets you intercept request of desktop apps like Spotify, Postman, Slack etc. You can try it out from here.
Posted on August 16, 2020
Join Our Newsletter. No Spam, Only the good stuff.
Sign up to receive the latest update from our blog.