summaryrefslogtreecommitdiff
path: root/internal/clients/runtime_boundary_test.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2026-03-10 20:01:15 +0200
committerPaul Buetow <paul@buetow.org>2026-03-10 20:01:15 +0200
commit71e431af2e65196ad4e7bc3404e772b1726d3338 (patch)
tree935e3b1af7c5b0033caf13ea00cf9655686b6ec9 /internal/clients/runtime_boundary_test.go
parentf6e23930da2900c43a5389a2e7d1e38d8221a76f (diff)
Introduce client runtime boundaries
Diffstat (limited to 'internal/clients/runtime_boundary_test.go')
-rw-r--r--internal/clients/runtime_boundary_test.go89
1 files changed, 89 insertions, 0 deletions
diff --git a/internal/clients/runtime_boundary_test.go b/internal/clients/runtime_boundary_test.go
new file mode 100644
index 0000000..9947865
--- /dev/null
+++ b/internal/clients/runtime_boundary_test.go
@@ -0,0 +1,89 @@
+package clients
+
+import (
+ "strings"
+ "testing"
+ "time"
+
+ "github.com/mimecast/dtail/internal/color"
+ "github.com/mimecast/dtail/internal/config"
+)
+
+func TestNewClientRuntimeBoundaryDefaults(t *testing.T) {
+ runtime := newClientRuntimeBoundary(config.RuntimeConfig{})
+
+ if runtime.SSHPort() != 2222 {
+ t.Fatalf("Expected default SSH port 2222, got %d", runtime.SSHPort())
+ }
+ if runtime.SSHConnectTimeout() != 2*time.Second {
+ t.Fatalf("Expected default timeout 2s, got %v", runtime.SSHConnectTimeout())
+ }
+ if runtime.InterruptPause() != 3*time.Second {
+ t.Fatalf("Expected default interrupt pause 3s, got %v", runtime.InterruptPause())
+ }
+ if got := runtime.output.PaintMaprRawQuery("select 1"); got != "select 1" {
+ t.Fatalf("Expected plain raw query output, got %q", got)
+ }
+}
+
+func TestNewClientRuntimeBoundaryUsesConfiguredSSHSettings(t *testing.T) {
+ runtime := newClientRuntimeBoundary(config.RuntimeConfig{
+ Common: &config.CommonConfig{
+ SSHPort: 4022,
+ SSHConnectTimeoutMs: 4500,
+ },
+ })
+
+ if runtime.SSHPort() != 4022 {
+ t.Fatalf("Expected configured SSH port 4022, got %d", runtime.SSHPort())
+ }
+ if runtime.SSHConnectTimeout() != 4500*time.Millisecond {
+ t.Fatalf("Expected configured timeout 4.5s, got %v", runtime.SSHConnectTimeout())
+ }
+}
+
+func TestClientOutputFormatterColorModes(t *testing.T) {
+ plain := newClientOutputFormatter(nil)
+ if got := plain.FormatInterruptMessage(1, "hello"); got != " hello" {
+ t.Fatalf("Expected plain interrupt message, got %q", got)
+ }
+ if got := plain.PaintMaprRawQuery("select 1"); got != "select 1" {
+ t.Fatalf("Expected plain raw query, got %q", got)
+ }
+
+ cfg := &config.ClientConfig{TermColorsEnable: true}
+ cfg.TermColors.Client.ClientFg = color.FgBlack
+ cfg.TermColors.Client.ClientBg = color.BgYellow
+ cfg.TermColors.Client.ClientAttr = color.AttrBold
+ cfg.TermColors.MaprTable.RawQueryFg = color.FgCyan
+ cfg.TermColors.MaprTable.RawQueryBg = color.BgBlack
+ cfg.TermColors.MaprTable.RawQueryAttr = color.AttrUnderline
+ cfg.TermColors.MaprTable.HeaderFg = color.FgWhite
+ cfg.TermColors.MaprTable.HeaderBg = color.BgBlue
+ cfg.TermColors.MaprTable.HeaderAttr = color.AttrBold
+ cfg.TermColors.MaprTable.HeaderDelimiterFg = color.FgWhite
+ cfg.TermColors.MaprTable.HeaderDelimiterBg = color.BgBlue
+ cfg.TermColors.MaprTable.HeaderDelimiterAttr = color.AttrDim
+ cfg.TermColors.MaprTable.HeaderSortKeyAttr = color.AttrUnderline
+ cfg.TermColors.MaprTable.HeaderGroupKeyAttr = color.AttrReverse
+ cfg.TermColors.MaprTable.DataFg = color.FgWhite
+ cfg.TermColors.MaprTable.DataBg = color.BgBlue
+ cfg.TermColors.MaprTable.DataAttr = color.AttrNone
+ cfg.TermColors.MaprTable.DelimiterFg = color.FgWhite
+ cfg.TermColors.MaprTable.DelimiterBg = color.BgBlue
+ cfg.TermColors.MaprTable.DelimiterAttr = color.AttrDim
+
+ colored := newClientOutputFormatter(cfg)
+ if got := colored.FormatInterruptMessage(0, "hello"); got != " hello" {
+ t.Fatalf("Expected first interrupt line to stay plain, got %q", got)
+ }
+ if got := colored.FormatInterruptMessage(1, "hello"); !strings.Contains(got, "\x1b[") {
+ t.Fatalf("Expected colored interrupt output, got %q", got)
+ }
+ if got := colored.PaintMaprRawQuery("select 1"); !strings.Contains(got, "\x1b[") {
+ t.Fatalf("Expected colored raw query output, got %q", got)
+ }
+ if colored.MaprResultRenderer() == nil {
+ t.Fatal("Expected non-nil mapreduce result renderer")
+ }
+}