summaryrefslogtreecommitdiffstats
path: root/remote/doc/Debugging.md
blob: 2cf03fcfca1e3f4656fbfd77ad7b2be6b1449679 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# Debugging

For other debugging resources, see also: Remote project [wiki]

## Increasing the logging verbosity

To increase the internal logging verbosity you can use the
`remote.log.level` [preference].

If you use mach to start Firefox:

```shell
% ./mach run --setpref "remote.log.level=Trace" --remote-debugging-port
```

By default, long log lines are truncated. To print long lines in full, you
can set `remote.log.truncate` to false.

## Enabling logging of emitted events

To dump events produced by EventEmitter,
including CDP events produced by the Remote Agent,
you can use the `toolkit.dump.emit` [preference]:

```shell
% ./mach run --setpref "toolkit.dump.emit=true" --remote-debugging-port
```

## Logging observer notifications

Observer notifications are used extensively throughout the
code and it can sometimes be useful to log these to see what is
available and when they are fired.

The `MOZ_LOG` environment variable controls the C++ logs and takes
the name of the subsystem along with a verbosity setting.  See
[prlog.h] for more details.

```shell
MOZ_LOG=ObserverService:5
```

You can optionally redirect logs away from stdout to a file:

```shell
MOZ_LOG_FILE=service.log
```

This enables `LogLevel::Debug` level information and places all
output in the file service.log in your current working directory.

[preference]: Prefs.md
[prlog.h]: https://searchfox.org/mozilla-central/source/nsprpub/pr/include/prlog.h
[wiki]: https://wiki.mozilla.org/Remote/Developer_Resources