]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commit
mgr: guard close_section calls in get_perf_schema_python 68213/head
authorLumir Sliva <61183145+lumir-sliva@users.noreply.github.com>
Sat, 4 Apr 2026 15:25:15 +0000 (17:25 +0200)
committerLumir Sliva <61183145+lumir-sliva@users.noreply.github.com>
Sat, 4 Apr 2026 15:25:15 +0000 (17:25 +0200)
commitb1c1ddaf0b771420e0905cd47e33919de5e11fd5
treee7d74c3d01cec8fb0392b831ea6b5dfd1ad1fe0d
parent1d146b4afffae5eb9031693f85cd9eabfc308679
mgr: guard close_section calls in get_perf_schema_python

When a daemon exists in the daemon state map but has no perf counters
(e.g. an OSD that was running but is now down or destroyed), the loop
in get_perf_schema_python never executes, leaving prev_key_name empty
and no formatter sections opened. The unconditional close_section()
calls after the loop then trigger an assertion failure in PyFormatter
(cursor != root).

Add the same `if (!prev_key_name.empty())` guard that already protects
the close_section() calls inside the loop, so we only close sections
that were actually opened.

Fixes: https://tracker.ceph.com/issues/75745
Signed-off-by: Lumir Sliva <61183145+lumir-sliva@users.noreply.github.com>
src/mgr/ActivePyModules.cc