summaryrefslogtreecommitdiff
path: root/integrationtests/dserver_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'integrationtests/dserver_test.go')
-rw-r--r--integrationtests/dserver_test.go53
1 files changed, 53 insertions, 0 deletions
diff --git a/integrationtests/dserver_test.go b/integrationtests/dserver_test.go
new file mode 100644
index 0000000..0944c79
--- /dev/null
+++ b/integrationtests/dserver_test.go
@@ -0,0 +1,53 @@
+package integrationtests
+
+import (
+ "context"
+ "fmt"
+ "os"
+ "testing"
+
+ "github.com/mimecast/dtail/internal/config"
+)
+
+func TestDServer(t *testing.T) {
+ if !config.Env("DTAIL_INTEGRATION_TEST_RUN_MODE") {
+ t.Log("Skipping")
+ return
+ }
+
+ csvFile := "dserver.csv"
+ expectedCsvFile := "dserver.csv.expected"
+ queryFile := fmt.Sprintf("%s.query", csvFile)
+ expectedQueryFile := "dserver.csv.query.expected"
+
+ ctx, cancel := context.WithCancel(context.Background())
+ defer cancel()
+
+ stdoutCh, stderrCh, cmdErrCh, err := startCommand(ctx, t,
+ "../dserver",
+ "--cfg", "dserver.cfg",
+ "--logger", "stdout",
+ "--logLevel", "info",
+ "--bindAddress", "localhost",
+ "--shutdownAfter", "5",
+ "--port", fmt.Sprintf("%d", getUniquePortNumber()),
+ )
+ if err != nil {
+ t.Error(err)
+ return
+ }
+
+ waitForCommand(ctx, t, stdoutCh, stderrCh, cmdErrCh)
+
+ if err := compareFiles(t, csvFile, expectedCsvFile); err != nil {
+ t.Error(err)
+ return
+ }
+ if err := compareFiles(t, queryFile, expectedQueryFile); err != nil {
+ t.Error(err)
+ return
+ }
+
+ os.Remove(csvFile)
+ os.Remove(queryFile)
+}