diff options
| author | Paul Buetow <paul@buetow.org> | 2026-05-27 08:40:35 +0300 |
|---|---|---|
| committer | Paul Buetow <paul@buetow.org> | 2026-05-27 08:40:35 +0300 |
| commit | 39b40239e55ca1a80579ffa4fb6584c8f14be73a (patch) | |
| tree | 017260670dc144ab6cdc1dd6a463271ee4a26664 /internal/tui/flamegraph/model_test.go | |
| parent | 116526ad2836778d4d1d27298515448a0a5c53cd (diff) | |
test(flamegraph): cover height edge branches (0p)
Diffstat (limited to 'internal/tui/flamegraph/model_test.go')
| -rw-r--r-- | internal/tui/flamegraph/model_test.go | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/internal/tui/flamegraph/model_test.go b/internal/tui/flamegraph/model_test.go index 3efe589..cbbacef 100644 --- a/internal/tui/flamegraph/model_test.go +++ b/internal/tui/flamegraph/model_test.go @@ -355,6 +355,47 @@ func TestZoomLineageParentsAreNeverNarrowerThanChildren(t *testing.T) { } } +func TestApplyZoomLineagePreservesHeightTotals(t *testing.T) { + snapshot := &snapshotNode{ + Name: "root", + Children: []*snapshotNode{ + { + Name: "A", + Children: []*snapshotNode{ + {Name: "A1", Total: 7, HeightTotal: 70}, + {Name: "A2", Total: 3, HeightTotal: 30}, + }, + }, + {Name: "B", Total: 4, HeightTotal: 40}, + }, + } + zoomPath := "root" + pathSeparator + "A" + zoomRoot := findNodeByPath(snapshot, zoomPath) + if zoomRoot == nil { + t.Fatalf("expected zoom root for %q", zoomPath) + } + zoomFrames := buildTerminalLayoutWithPath(zoomRoot, 100, 20, zoomPath) + zoomRootFrame := mustFindFrame(t, zoomFrames, zoomPath) + if got, want := zoomRootFrame.HeightTotal, uint64(100); got != want { + t.Fatalf("zoom root HeightTotal = %d, want %d before lineage", got, want) + } + + frames := applyZoomLineage(zoomFrames, snapshot, zoomPath, 100) + root := mustFindFrame(t, frames, "root") + zoom := mustFindFrame(t, frames, zoomPath) + leaf := mustFindFrame(t, frames, zoomPath+pathSeparator+"A1") + + if got, want := root.HeightTotal, uint64(140); got != want { + t.Fatalf("lineage root HeightTotal = %d, want %d", got, want) + } + if got, want := zoom.HeightTotal, zoomRootFrame.HeightTotal; got != want { + t.Fatalf("lineage zoom HeightTotal = %d, want %d", got, want) + } + if got, want := leaf.HeightTotal, uint64(70); got != want { + t.Fatalf("descendant HeightTotal = %d, want %d", got, want) + } +} + func TestMouseClickOnLineageAncestorUndoesToThatZoomLevel(t *testing.T) { m := newZoomModel() m.selectedIdx = mustFrameIndex(t, m.frames, "root"+pathSeparator+"A") |
