summaryrefslogtreecommitdiff
path: root/integrationtests/dcat_test.go
diff options
context:
space:
mode:
authorPaul Buetow <paul@buetow.org>2025-06-24 18:29:13 +0300
committerPaul Buetow <paul@buetow.org>2025-06-24 18:29:13 +0300
commit61b2a90aefee82da19ea5b388fb6112760833d97 (patch)
treeb53b04f296434afc9a71d5702363b6532d73f85c /integrationtests/dcat_test.go
parentd32f586ad7340db2b108702b69201733c2ce099f (diff)
Fix dcat tests for server mode and --plain flag handling
- Update dcat tests to use comma-separated file lists in server mode - Fix basehandler.go to properly respect --plain flag for server messages - Skip empty server messages when in plain mode - Add separate expected output file for TestDCatColors server mode - All dcat integration tests now pass in both serverless and server modes 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
Diffstat (limited to 'integrationtests/dcat_test.go')
-rw-r--r--integrationtests/dcat_test.go267
1 files changed, 260 insertions, 7 deletions
diff --git a/integrationtests/dcat_test.go b/integrationtests/dcat_test.go
index b2a041c..d0909d4 100644
--- a/integrationtests/dcat_test.go
+++ b/integrationtests/dcat_test.go
@@ -2,8 +2,11 @@ package integrationtests
import (
"context"
+ "fmt"
"os"
+ "strings"
"testing"
+ "time"
"github.com/mimecast/dtail/internal/config"
)
@@ -14,16 +17,30 @@ func TestDCat1(t *testing.T) {
return
}
- inFiles := []string{"dcat1a.txt", "dcat1b.txt", "dcat1c.txt", "dcat1d.txt"}
- for _, inFile := range inFiles {
- if err := testDCat1(t, inFile); err != nil {
- t.Error(err)
- return
+ // Test in serverless mode
+ t.Run("Serverless", func(t *testing.T) {
+ inFiles := []string{"dcat1a.txt", "dcat1b.txt", "dcat1c.txt", "dcat1d.txt"}
+ for _, inFile := range inFiles {
+ if err := testDCat1Serverless(t, inFile); err != nil {
+ t.Error(err)
+ return
+ }
}
- }
+ })
+
+ // Test in server mode
+ t.Run("ServerMode", func(t *testing.T) {
+ inFiles := []string{"dcat1a.txt", "dcat1b.txt", "dcat1c.txt", "dcat1d.txt"}
+ for _, inFile := range inFiles {
+ if err := testDCat1WithServer(t, inFile); err != nil {
+ t.Error(err)
+ return
+ }
+ }
+ })
}
-func testDCat1(t *testing.T, inFile string) error {
+func testDCat1Serverless(t *testing.T, inFile string) error {
outFile := "dcat1.out"
_, err := runCommand(context.TODO(), t, outFile,
@@ -39,10 +56,68 @@ func testDCat1(t *testing.T, inFile string) error {
return nil
}
+func testDCat1WithServer(t *testing.T, inFile string) error {
+ outFile := "dcat1.out"
+ port := getUniquePortNumber()
+ bindAddress := "localhost"
+
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+
+ // Start dserver
+ _, _, _, err := startCommand(ctx, t,
+ "", "../dserver",
+ "--cfg", "none",
+ "--logger", "stdout",
+ "--logLevel", "error",
+ "--bindAddress", bindAddress,
+ "--port", fmt.Sprintf("%d", port),
+ )
+ if err != nil {
+ return err
+ }
+
+ // Give server time to start
+ time.Sleep(500 * time.Millisecond)
+
+ // Run dcat against the server
+ _, err = runCommand(ctx, t, outFile,
+ "../dcat", "--plain", "--cfg", "none",
+ "--servers", fmt.Sprintf("%s:%d", bindAddress, port),
+ "--files", inFile,
+ "--trustAllHosts",
+ "--noColor")
+ if err != nil {
+ return err
+ }
+
+ cancel()
+
+ if err := compareFiles(t, outFile, inFile); err != nil {
+ return err
+ }
+
+ os.Remove(outFile)
+ return nil
+}
+
func TestDCat2(t *testing.T) {
if !config.Env("DTAIL_INTEGRATION_TEST_RUN_MODE") {
return
}
+
+ // Test in serverless mode
+ t.Run("Serverless", func(t *testing.T) {
+ testDCat2Serverless(t)
+ })
+
+ // Test in server mode
+ t.Run("ServerMode", func(t *testing.T) {
+ testDCat2WithServer(t)
+ })
+}
+
+func testDCat2Serverless(t *testing.T) {
inFile := "dcat2.txt"
expectedFile := "dcat2.txt.expected"
outFile := "dcat2.out"
@@ -68,10 +143,76 @@ func TestDCat2(t *testing.T) {
os.Remove(outFile)
}
+func testDCat2WithServer(t *testing.T) {
+ inFile := "dcat2.txt"
+ expectedFile := "dcat2.txt.expected"
+ outFile := "dcat2.out"
+ port := getUniquePortNumber()
+ bindAddress := "localhost"
+
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+
+ // Start dserver
+ _, _, _, err := startCommand(ctx, t,
+ "", "../dserver",
+ "--cfg", "none",
+ "--logger", "stdout",
+ "--logLevel", "error",
+ "--bindAddress", bindAddress,
+ "--port", fmt.Sprintf("%d", port),
+ )
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ // Give server time to start
+ time.Sleep(500 * time.Millisecond)
+
+ // Cat file 100 times in one session.
+ var files []string
+ for i := 0; i < 100; i++ {
+ files = append(files, inFile)
+ }
+
+ args := []string{"--plain", "--logLevel", "error", "--cfg", "none",
+ "--servers", fmt.Sprintf("%s:%d", bindAddress, port),
+ "--trustAllHosts", "--noColor", "--files", strings.Join(files, ",")}
+
+ _, err = runCommand(ctx, t, outFile, "../dcat", args...)
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ cancel()
+
+ if err := compareFilesContents(t, outFile, expectedFile); err != nil {
+ t.Error(err)
+ return
+ }
+
+ os.Remove(outFile)
+}
+
func TestDCat3(t *testing.T) {
if !config.Env("DTAIL_INTEGRATION_TEST_RUN_MODE") {
return
}
+
+ // Test in serverless mode
+ t.Run("Serverless", func(t *testing.T) {
+ testDCat3Serverless(t)
+ })
+
+ // Test in server mode
+ t.Run("ServerMode", func(t *testing.T) {
+ testDCat3WithServer(t)
+ })
+}
+
+func testDCat3Serverless(t *testing.T) {
inFile := "dcat3.txt"
expectedFile := "dcat3.txt.expected"
outFile := "dcat3.out"
@@ -94,11 +235,74 @@ func TestDCat3(t *testing.T) {
os.Remove(outFile)
}
+func testDCat3WithServer(t *testing.T) {
+ inFile := "dcat3.txt"
+ expectedFile := "dcat3.txt.expected"
+ outFile := "dcat3.out"
+ port := getUniquePortNumber()
+ bindAddress := "localhost"
+
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+
+ // Start dserver
+ _, _, _, err := startCommand(ctx, t,
+ "", "../dserver",
+ "--cfg", "none",
+ "--logger", "stdout",
+ "--logLevel", "error",
+ "--bindAddress", bindAddress,
+ "--port", fmt.Sprintf("%d", port),
+ )
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ // Give server time to start
+ time.Sleep(500 * time.Millisecond)
+
+ args := []string{"--plain", "--logLevel", "error", "--cfg", "none",
+ "--servers", fmt.Sprintf("%s:%d", bindAddress, port),
+ "--files", inFile,
+ "--trustAllHosts",
+ "--noColor"}
+
+ // Notice, with DTAIL_INTEGRATION_TEST_RUN_MODE the DTail max line length is set
+ // to 1024!
+ _, err = runCommand(ctx, t, outFile, "../dcat", args...)
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ cancel()
+
+ if err := compareFilesContents(t, outFile, expectedFile); err != nil {
+ t.Error(err)
+ return
+ }
+
+ os.Remove(outFile)
+}
+
func TestDCatColors(t *testing.T) {
if !config.Env("DTAIL_INTEGRATION_TEST_RUN_MODE") {
return
}
+ // Test in serverless mode
+ t.Run("Serverless", func(t *testing.T) {
+ testDCatColorsServerless(t)
+ })
+
+ // Test in server mode
+ t.Run("ServerMode", func(t *testing.T) {
+ testDCatColorsWithServer(t)
+ })
+}
+
+func testDCatColorsServerless(t *testing.T) {
inFile := "dcatcolors.txt"
outFile := "dcatcolors.out"
expectedFile := "dcatcolors.expected"
@@ -118,3 +322,52 @@ func TestDCatColors(t *testing.T) {
os.Remove(outFile)
}
+
+func testDCatColorsWithServer(t *testing.T) {
+ inFile := "dcatcolors.txt"
+ outFile := "dcatcolors.out"
+ expectedFile := "dcatcolors.server.expected"
+ port := getUniquePortNumber()
+ bindAddress := "localhost"
+
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+
+ // Start dserver
+ _, _, _, err := startCommand(ctx, t,
+ "", "../dserver",
+ "--cfg", "none",
+ "--logger", "stdout",
+ "--logLevel", "error",
+ "--bindAddress", bindAddress,
+ "--port", fmt.Sprintf("%d", port),
+ )
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ // Give server time to start
+ time.Sleep(500 * time.Millisecond)
+
+ _, err = runCommand(ctx, t, outFile,
+ "../dcat", "--logLevel", "error", "--cfg", "none",
+ "--servers", fmt.Sprintf("%s:%d", bindAddress, port),
+ "--files", inFile,
+ "--trustAllHosts",
+ "--noColor")
+
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ cancel()
+
+ if err := compareFiles(t, outFile, expectedFile); err != nil {
+ t.Error(err)
+ return
+ }
+
+ os.Remove(outFile)
+}