summaryrefslogtreecommitdiff
path: root/internal/tui/flamegraph/controls_test.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-05-27 08:40:35 +0300
committerPaul Buetow <paul@buetow.org>2026-05-27 08:40:35 +0300
commit39b40239e55ca1a80579ffa4fb6584c8f14be73a (patch)
tree017260670dc144ab6cdc1dd6a463271ee4a26664 /internal/tui/flamegraph/controls_test.go
parent116526ad2836778d4d1d27298515448a0a5c53cd (diff)
test(flamegraph): cover height edge branches (0p)
Diffstat (limited to 'internal/tui/flamegraph/controls_test.go')
-rw-r--r--internal/tui/flamegraph/controls_test.go86
1 files changed, 86 insertions, 0 deletions
diff --git a/internal/tui/flamegraph/controls_test.go b/internal/tui/flamegraph/controls_test.go
new file mode 100644
index 0000000..4a703fd
--- /dev/null
+++ b/internal/tui/flamegraph/controls_test.go
@@ -0,0 +1,86 @@
+package flamegraph
+
+import (
+ "errors"
+ "testing"
+
+ coreflamegraph "ior/internal/flamegraph"
+)
+
+type setHeightErrorTrie struct {
+ *coreflamegraph.LiveTrie
+ err error
+}
+
+func (t *setHeightErrorTrie) SetHeightField(string) error {
+ return t.err
+}
+
+type forcedHeightFieldTrie struct {
+ *coreflamegraph.LiveTrie
+ field string
+}
+
+func (t *forcedHeightFieldTrie) HeightField() string {
+ return t.field
+}
+
+func TestToggleHeightFieldErrorKeepsExistingState(t *testing.T) {
+ base := coreflamegraph.NewLiveTrie([]string{"comm", "path", "tracepoint"}, "count", "")
+ liveTrie := &setHeightErrorTrie{
+ LiveTrie: base,
+ err: errors.New("set-height failed"),
+ }
+ m := NewModel(liveTrie)
+ m.snapshot = &snapshotNode{Name: "root", Total: 10}
+ m.frames = []tuiFrame{{Name: "root", Path: "root", Total: 10}}
+
+ m.toggleHeightField()
+
+ if got, want := m.heightField, ""; got != want {
+ t.Fatalf("heightField = %q, want %q on SetHeightField error", got, want)
+ }
+ if got, want := m.statusMessage, "Height toggle error: set-height failed"; got != want {
+ t.Fatalf("statusMessage = %q, want %q", got, want)
+ }
+ if m.snapshot == nil || len(m.frames) == 0 {
+ t.Fatalf("expected snapshot/layout state to remain intact on SetHeightField error")
+ }
+}
+
+func TestHeightFieldLabelReturnsRawValueForUnknownField(t *testing.T) {
+ m := NewModel(nil)
+ m.heightField = "custom-height"
+
+ if got, want := m.heightFieldLabel(), "custom-height"; got != want {
+ t.Fatalf("heightFieldLabel() = %q, want %q", got, want)
+ }
+}
+
+func TestSyncHeightFieldToTrieNilLiveTrieClearsField(t *testing.T) {
+ m := NewModel(nil)
+ m.heightField = "bytes"
+
+ m.syncHeightFieldToTrie()
+
+ if got, want := m.heightField, ""; got != want {
+ t.Fatalf("heightField = %q, want %q for nil liveTrie", got, want)
+ }
+}
+
+func TestSyncHeightFieldToTrieUnknownFieldFallsBackToOff(t *testing.T) {
+ base := coreflamegraph.NewLiveTrie([]string{"comm", "path", "tracepoint"}, "count", "")
+ liveTrie := &forcedHeightFieldTrie{
+ LiveTrie: base,
+ field: "mystery",
+ }
+ m := NewModel(nil)
+ m.liveTrie = liveTrie
+ m.heightField = "duration"
+
+ m.syncHeightFieldToTrie()
+
+ if got, want := m.heightField, ""; got != want {
+ t.Fatalf("heightField = %q, want %q for unknown trie height field", got, want)
+ }
+}