-
-
Notifications
You must be signed in to change notification settings - Fork 2.1k
Getting a crash log out of Element Desktop
Sometimes, Element Desktop crashes.
A crash manifests itself in two ways:
- The entire app crashes, causing it to disappear. This means the main Electron process has crashed.
- The app's screen goes entirely white. This means the render process of Electron has crashed.
If you instead experience JS errors, spinners that don't go away, or some other breakage - that's not technically a crash, and you should instead report the problem via submitting debug logs (top right menu -> Feedback -> Debug logs). This article is strictly for when you experience a crash of the Electron process.
In order for anyone to work on your issue, you'll need to create a crash log. How difficult this is depends on your system.
Open Console.app (in Applications -> Utilities) and go to Crash Reports. You should be able to see an entry that corresponds to Element crashing. Copy and paste the contents of that report into a comment on the defect issue that you've created.
It depends on your system. The overall idea is
- Configure your system to produce a "core dump" when Element crashes
- Open the core dump in
gdb
, runbt
, and copy and paste the results.
- Arch: https://wiki.archlinux.org/title/Core_dump#Examining_a_core_dump
- Ubuntu: https://askubuntu.com/questions/966407/where-do-i-find-the-core-dump-in-ubuntu-16-04lts#:~:text=In%20Ubuntu%20the%20core%20dumps,or%20sudo%20service%20apport%20start%20.
With these instructions you can retrieve the stack trace after a crash. Tested on Ubuntu 22.04 LTS:
- Search for
electron@
withinyarn.lock
in the Element Desktop repo - Note the version, e.g.
version "24.3.1"
- Download the debug build for the same version from here
- Extract the contents of
debug
from the archive to/opt/Element
(or/opt/Element-Nightly
for the nightly version) - If Element crashes let the system create a crash report
- Open a terminal
- Go to
/var/crash
- Run
apport-unpack _opt_Element-Nightly_element-desktop-nightly.1000.crash /tmp/elecrash
cd /tmp/elecrash
- The stacktrace is located in the
Stacktrace
file there
On most Linux builds, Element doesn't include debug symbols, which means it's still quite hard to tell what's going on - the crash dump won't contain the names of functions that the program is in, just which libraries are being used.
It's possible to make an unstripped build which includes those symbols; how to do this varies according to which package you're using. See here for some suggestions on how to accomplish this on Arch Linux.
Windows generates crash dump files which you can send to an Element maintainer for analysis. These files contain an image of what you've been doing in Element, so this only a sensible option if you're not concerned about the privacy of your data.
The crash dump file will be located in %LOCALAPPDATA%\CrashDumps
on your system. This article has more details.