From 10de8be826064f4436149c3910e02c44b83e260e Mon Sep 17 00:00:00 2001 From: Michal Pristas Date: Fri, 17 Apr 2020 11:50:45 +0200 Subject: [PATCH] [Agent] Windows spawning process fix (#17751) [Agent] Windows spawning process fix (#17751) --- x-pack/elastic-agent/CHANGELOG.asciidoc | 1 + x-pack/elastic-agent/pkg/core/plugin/process/cmd.go | 2 ++ x-pack/elastic-agent/pkg/core/plugin/process/process.go | 7 +++++-- 3 files changed, 8 insertions(+), 2 deletions(-) diff --git a/x-pack/elastic-agent/CHANGELOG.asciidoc b/x-pack/elastic-agent/CHANGELOG.asciidoc index 299dbf85bde..826f6e2ccb7 100644 --- a/x-pack/elastic-agent/CHANGELOG.asciidoc +++ b/x-pack/elastic-agent/CHANGELOG.asciidoc @@ -18,6 +18,7 @@ - Fixed merge of config {pull}17399[17399] - Handle abs paths on windows correctly {pull}17461[17461] - Improved cancellation of agent {pull}17318[17318] +- Fixed process spawning on Windows {pull}17751[17751] ==== New features diff --git a/x-pack/elastic-agent/pkg/core/plugin/process/cmd.go b/x-pack/elastic-agent/pkg/core/plugin/process/cmd.go index 98d3abe30e8..d1541a05e18 100644 --- a/x-pack/elastic-agent/pkg/core/plugin/process/cmd.go +++ b/x-pack/elastic-agent/pkg/core/plugin/process/cmd.go @@ -10,6 +10,7 @@ package process import ( "os" "os/exec" + "path/filepath" "github.com/elastic/beats/v7/x-pack/elastic-agent/pkg/core/logger" ) @@ -18,6 +19,7 @@ func getCmd(logger *logger.Logger, path string, env []string, uid, gid int, arg cmd := exec.Command(path, arg...) cmd.Env = append(cmd.Env, os.Environ()...) cmd.Env = append(cmd.Env, env...) + cmd.Dir = filepath.Dir(path) return cmd } diff --git a/x-pack/elastic-agent/pkg/core/plugin/process/process.go b/x-pack/elastic-agent/pkg/core/plugin/process/process.go index 3ce192ced44..4cb9f770231 100644 --- a/x-pack/elastic-agent/pkg/core/plugin/process/process.go +++ b/x-pack/elastic-agent/pkg/core/plugin/process/process.go @@ -191,14 +191,17 @@ func pushCredentials(w io.Writer, c *Creds) error { credbytes, err := yaml.Marshal(c) if err != nil { - return err + return errors.New(err, "decoding credentials") } _, err = w.Write(credbytes) + if err != nil { + return errors.New(err, "passing credentials failed") + } // this gives beat with grpc a bit of time to spin up a goroutine and start a server. // should be ok until we come up with more clever solution. // Issue: https://github.com/elastic/beats/v7/issues/15634 <-time.After(1500 * time.Millisecond) - return err + return nil }