From 590c343e1cffefa08984636cce3a05af2f2539a1 Mon Sep 17 00:00:00 2001 From: VladislavSenkevich Date: Mon, 13 Jun 2022 17:27:00 +0300 Subject: [PATCH 1/2] feat(outputs.groundwork): Make application type configurable --- plugins/outputs/groundwork/README.md | 3 +++ plugins/outputs/groundwork/groundwork.go | 9 +++++++-- plugins/outputs/groundwork/groundwork_test.go | 5 +++-- 3 files changed, 13 insertions(+), 4 deletions(-) diff --git a/plugins/outputs/groundwork/README.md b/plugins/outputs/groundwork/README.md index e11febc6b0d49..738928004fc3b 100644 --- a/plugins/outputs/groundwork/README.md +++ b/plugins/outputs/groundwork/README.md @@ -19,6 +19,9 @@ GW8+ ## Username and password to access GroundWork API. username = "" password = "" + + ## Default Application Type to use in Groundwork Client + # default_app_type = "telegraf" ## Default display name for the host with services(metrics). # default_host = "telegraf" diff --git a/plugins/outputs/groundwork/groundwork.go b/plugins/outputs/groundwork/groundwork.go index ede4dbd5aa726..28a62353d5ecf 100644 --- a/plugins/outputs/groundwork/groundwork.go +++ b/plugins/outputs/groundwork/groundwork.go @@ -33,6 +33,7 @@ type Groundwork struct { AgentID string `toml:"agent_id"` Username string `toml:"username"` Password string `toml:"password"` + DefaultAppType string `toml:"default_app_type"` DefaultHost string `toml:"default_host"` DefaultServiceState string `toml:"default_service_state"` GroupTag string `toml:"group_tag"` @@ -58,6 +59,9 @@ func (g *Groundwork) Init() error { if g.Password == "" { return errors.New("no 'password' provided") } + if g.DefaultAppType == "" { + return errors.New("no 'default_app_type' provided") + } if g.DefaultHost == "" { return errors.New("no 'default_host' provided") } @@ -70,7 +74,7 @@ func (g *Groundwork) Init() error { g.client = clients.GWClient{ AppName: "telegraf", - AppType: "TELEGRAF", + AppType: g.DefaultAppType, GWConnection: &clients.GWConnection{ HostName: g.Server, UserName: g.Username, @@ -172,7 +176,7 @@ func (g *Groundwork) Write(metrics []telegraf.Metric) error { } requestJSON, err := json.Marshal(transit.ResourcesWithServicesRequest{ Context: &transit.TracerContext{ - AppType: "TELEGRAF", + AppType: g.DefaultAppType, AgentID: g.AgentID, TraceToken: traceToken, TimeStamp: transit.NewTimestamp(), @@ -200,6 +204,7 @@ func init() { GroupTag: "group", ResourceTag: "host", DefaultHost: "telegraf", + DefaultAppType: "TELEGRAF", DefaultServiceState: string(transit.ServiceOk), } }) diff --git a/plugins/outputs/groundwork/groundwork_test.go b/plugins/outputs/groundwork/groundwork_test.go index 28d5766da2195..2027ec713e2b4 100644 --- a/plugins/outputs/groundwork/groundwork_test.go +++ b/plugins/outputs/groundwork/groundwork_test.go @@ -18,6 +18,7 @@ import ( const ( defaultTestAgentID = "ec1676cc-583d-48ee-b035-7fb5ed0fcf88" defaultHost = "telegraf" + defaultAppType = "TELEGRAF" ) func TestWriteWithDefaults(t *testing.T) { @@ -51,7 +52,7 @@ func TestWriteWithDefaults(t *testing.T) { DefaultHost: defaultHost, client: clients.GWClient{ AppName: "telegraf", - AppType: "TELEGRAF", + AppType: defaultAppType, GWConnection: &clients.GWConnection{ HostName: server.URL, }, @@ -100,7 +101,7 @@ func TestWriteWithTags(t *testing.T) { ResourceTag: "host", client: clients.GWClient{ AppName: "telegraf", - AppType: "TELEGRAF", + AppType: defaultAppType, GWConnection: &clients.GWConnection{ HostName: server.URL, }, From 42c3e40d07cb87c43f732087b85f27c8d26a3253 Mon Sep 17 00:00:00 2001 From: VladislavSenkevich Date: Tue, 14 Jun 2022 14:13:10 +0300 Subject: [PATCH 2/2] feat(outputs.groundwork): Improve test to check for appType --- plugins/outputs/groundwork/README.md | 4 ++-- plugins/outputs/groundwork/groundwork_test.go | 24 ++++++++++++------- 2 files changed, 17 insertions(+), 11 deletions(-) diff --git a/plugins/outputs/groundwork/README.md b/plugins/outputs/groundwork/README.md index 738928004fc3b..b75bc83603c56 100644 --- a/plugins/outputs/groundwork/README.md +++ b/plugins/outputs/groundwork/README.md @@ -20,8 +20,8 @@ GW8+ username = "" password = "" - ## Default Application Type to use in Groundwork Client - # default_app_type = "telegraf" + ## Default application type to use in GroundWork client + # default_app_type = "TELEGRAF" ## Default display name for the host with services(metrics). # default_host = "telegraf" diff --git a/plugins/outputs/groundwork/groundwork_test.go b/plugins/outputs/groundwork/groundwork_test.go index 2027ec713e2b4..86b0870e17a11 100644 --- a/plugins/outputs/groundwork/groundwork_test.go +++ b/plugins/outputs/groundwork/groundwork_test.go @@ -19,6 +19,7 @@ const ( defaultTestAgentID = "ec1676cc-583d-48ee-b035-7fb5ed0fcf88" defaultHost = "telegraf" defaultAppType = "TELEGRAF" + customAppType = "SYSLOG" ) func TestWriteWithDefaults(t *testing.T) { @@ -37,6 +38,7 @@ func TestWriteWithDefaults(t *testing.T) { // Check if server gets valid metrics object require.Equal(t, defaultTestAgentID, obj.Context.AgentID) + require.Equal(t, customAppType, obj.Context.AppType) require.Equal(t, defaultHost, obj.Resources[0].Name) require.Equal(t, "IntMetric", obj.Resources[0].Services[0].Name) require.Equal(t, int64(42), obj.Resources[0].Services[0].Metrics[0].Value.IntegerValue) @@ -47,12 +49,13 @@ func TestWriteWithDefaults(t *testing.T) { })) i := Groundwork{ - Server: server.URL, - AgentID: defaultTestAgentID, - DefaultHost: defaultHost, + Server: server.URL, + AgentID: defaultTestAgentID, + DefaultHost: defaultHost, + DefaultAppType: customAppType, client: clients.GWClient{ AppName: "telegraf", - AppType: defaultAppType, + AppType: customAppType, GWConnection: &clients.GWConnection{ HostName: server.URL, }, @@ -83,6 +86,7 @@ func TestWriteWithTags(t *testing.T) { // Check if server gets valid metrics object require.Equal(t, defaultTestAgentID, obj.Context.AgentID) + require.Equal(t, defaultAppType, obj.Context.AppType) require.Equal(t, "Host01", obj.Resources[0].Name) require.Equal(t, "FloatMetric", obj.Resources[0].Services[0].Name) require.Equal(t, 1.0, obj.Resources[0].Services[0].Metrics[0].Value.DoubleValue) @@ -94,11 +98,12 @@ func TestWriteWithTags(t *testing.T) { })) i := Groundwork{ - Server: server.URL, - AgentID: defaultTestAgentID, - DefaultHost: defaultHost, - GroupTag: "group", - ResourceTag: "host", + Server: server.URL, + AgentID: defaultTestAgentID, + DefaultHost: defaultHost, + DefaultAppType: defaultAppType, + GroupTag: "group", + ResourceTag: "host", client: clients.GWClient{ AppName: "telegraf", AppType: defaultAppType, @@ -117,6 +122,7 @@ func TestWriteWithTags(t *testing.T) { type groundworkObject struct { Context struct { AgentID string `json:"agentId"` + AppType string `json:"appType"` } `json:"context"` Resources []struct { Name string `json:"name"`