Find a file
Kate Hsuan fe36d9ee4a linux: integration-test: fix random test failure for test_bluetooth_hidpp_mouse
Sometime we found the errors shows below when pipeline test was running.

379s ERROR: test_bluetooth_hidpp_mouse (__main__.Tests.test_bluetooth_hidpp_mouse)
379s Logitech Bluetooth LE mouse with HID++ kernel support
379s ----------------------------------------------------------------------
379s Traceback (most recent call last):
379s   File "/usr/libexec/upower/integration-test.py", line 4380, in test_bluetooth_hidpp_mouse
379s     self.assertEventually(
379s     ~~~~~~~~~~~~~~~~~~~~~^
379s         lambda: self.get_dbus_dev_property(bat0_up, "Model"), value=alias
379s         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
379s     )
379s     ^
379s   File "/usr/libexec/upower/integration-test.py", line 399, in assertEventually
379s     if condition() == value:
379s        ~~~~~~~~~^^
379s   File "/usr/libexec/upower/integration-test.py", line 4381, in <lambda>
379s     lambda: self.get_dbus_dev_property(bat0_up, "Model"), value=alias
379s             ~~~~~~~~~~~~~~~~~~~~~~~~~~^^^^^^^^^^^^^^^^^^
379s   File "/usr/libexec/upower/integration-test.py", line 316, in get_dbus_dev_property
379s     return self.dbus.call_sync(
379s            ~~~~~~~~~~~~~~~~~~~^
379s         UP,
379s         ^^^
379s     ...<7 lines>...
379s         None,
379s         ^^^^^
379s     ).unpack()[0]
379s     ^
379s gi.repository.GLib.GError: g-dbus-error-quark: GDBus.Error:org.freedesktop.DBus.Error.UnknownMethod: Object does not exist at path “/org/freedesktop/UPower/devices/mouse_dev_11_22_33_44_AA_BB” (19)
379s

The upower and bluez daemons were started after the udev was
initialized to avoid the random errors.
2025-08-07 12:34:35 +08:00
.ci Reformat python code style with black 2025-01-08 14:01:34 +08:00
contrib contrib: setup: Install and setup pre-commit 2025-01-13 08:55:18 +00:00
data/zsh-completion add completions for CLI 2024-10-26 19:56:28 +00:00
dbus dbus: Define CapacityLevel, VoltageMinDesign and VoltageMaxDesign properties 2025-04-16 14:38:56 +08:00
doc docs: Document all upower(1) command-line options 2025-06-04 10:45:41 -07:00
etc etc/UPower.conf: fix "riscky" typo 2025-01-13 13:30:11 +08:00
libupower-glib lib: up-device: Expose CapacityLevel, VoltageMinDesign, and VoltageMaxDesign 2025-04-16 15:08:39 +08:00
po Update LINGUAS 2025-01-17 02:11:22 +00:00
policy Revert "policy: Remove policy for removed features" 2024-08-22 14:20:33 +08:00
rules rules: 95-upower-hid.hwdb: update hwdb for HID devices 2025-03-25 17:08:40 +08:00
src linux: integration-test: fix random test failure for test_bluetooth_hidpp_mouse 2025-08-07 12:34:35 +08:00
tools tools: Reorder upower(1) command-line options to match manual page 2025-06-04 10:45:49 -07:00
.git-blame-ignore-revs Ignore commits for tree wide changes 2025-01-08 16:54:58 +08:00
.gitconfig Ignore commits for tree wide changes 2025-01-08 16:54:58 +08:00
.gitlab-ci.yml ci: Add a pre-commit stage 2025-01-08 14:01:34 +08:00
.markdownlint.json ci: markdownlint: Add markdownlint to the pre-commit check 2025-01-08 13:59:50 +08:00
.pre-commit-config.yaml pre-commit-config: Remove deprecated default_stages "commit" 2025-01-13 08:55:18 +00:00
AUTHORS trivial: add my copyright 2008-09-06 11:12:24 +01:00
code-of-conduct.md Add code of conduct document 2019-07-25 12:08:15 +02:00
COMMITMENT Add COMMITMENT file as part of GPL Common Cure Rights Commitment 2018-06-18 16:11:43 +01:00
COPYING trivial: Rename a few 'DeviceKit-power' strings we missed 2010-05-28 15:00:07 +01:00
HACKING.md Ignore commits for tree wide changes 2025-01-08 16:54:58 +08:00
meson.build Release 1.90.9 2025-04-10 14:35:54 +08:00
meson_options.txt add completions for CLI 2024-10-26 19:56:28 +00:00
NEWS Release 1.90.9 2025-04-10 14:35:54 +08:00
README.md README: Rename to README.md and fix markdown with markdownlint 2025-01-08 14:25:55 +08:00
RELEASE RELEASE: Update notes on how to do releases 2022-02-09 17:53:54 +01:00

UPower

Requirements:

  glib-2.0             >= 2.66.0
  gio-2.0              >= 2.16.1
  gudev-1.0            >= 235    (Linux)
  libimobiledevice-1.0 >= 0.9.7  (optional)
  polkit-gobject-1     >= 124

UPower is an abstraction for enumerating power devices, listening to device events and querying history and statistics. Any application or service on the system can access the org.freedesktop.UPower service via the system message bus.

Debugging

When doing bug reports, the following information can be useful:

  • grep . /sys/class/power_supply/*/*
    This includes the current kernel view of all power supplies in the system. It is always a good idea to include this information.
  • udevadm info -e
    This shows the hardware configuration and is relevant when e.g. the type of an external device is misdetected.
  • upower -d
    Shows upower's view of the state
  • upower --monitor-detail
    Dumps device information every time that a change happens. This helps with debugging dynamic issues.
  • udevadm monitor
    Dumps the udev/kernel reported hardware changes (and addition/removal). This is helpful when debugging dynamic issues, in particular if it is not clear whether the issue is coming from the kernel or upower.

In addition, it can also be useful to run upower in debug mode and post the logs. There are two ways of doing so:

  • Run upower daemon manually, you can do so using: sudo /usr/libexec/upowerd -rd
  • Modify the systemd service and restart. This is best done by:
    1. sudo systemctl edit upower.service

    2. Adding the two lines:

      [Service]
      Environment=G_MESSAGES_DEBUG=all
      
    3. sudo systemctl restart upower.service

    4. Grab logs using journalctl -u upower.service or similar