Plugins: Tracing: Disable distributed tracing for plugins by default (#65796)

* Plugins: Tracing: Disable tracing by default, pass GF_VERSION only if tracing is enabled

* Plugins: Tracing: Fix GF_PLUGIN_VERSION instead of GF_VERSION
pull/65797/head
Giuseppe Guerra 2 years ago committed by GitHub
parent c63cb5a0bd
commit 2647b2e0f9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 10
      pkg/plugins/manager/loader/initializer/initializer.go
  2. 200
      pkg/plugins/manager/loader/initializer/initializer_test.go

@ -51,9 +51,6 @@ func (i *Initializer) envVars(plugin *plugins.Plugin) []string {
hostEnv := []string{ hostEnv := []string{
fmt.Sprintf("GF_VERSION=%s", i.cfg.BuildVersion), fmt.Sprintf("GF_VERSION=%s", i.cfg.BuildVersion),
} }
if plugin.Info.Version != "" {
hostEnv = append(hostEnv, fmt.Sprintf("GF_PLUGIN_VERSION=%s", plugin.Info.Version))
}
if i.license != nil { if i.license != nil {
hostEnv = append( hostEnv = append(
@ -69,11 +66,14 @@ func (i *Initializer) envVars(plugin *plugins.Plugin) []string {
hostEnv = append(hostEnv, azsettings.WriteToEnvStr(i.cfg.Azure)...) hostEnv = append(hostEnv, azsettings.WriteToEnvStr(i.cfg.Azure)...)
// Tracing // Tracing
pluginTracingEnabled := true var pluginTracingEnabled bool
if v, exists := i.cfg.PluginSettings[plugin.ID]["tracing"]; exists { if v, exists := i.cfg.PluginSettings[plugin.ID]["tracing"]; exists {
pluginTracingEnabled = v != "false" pluginTracingEnabled = v == "true"
} }
if i.cfg.Opentelemetry.IsEnabled() && pluginTracingEnabled { if i.cfg.Opentelemetry.IsEnabled() && pluginTracingEnabled {
if plugin.Info.Version != "" {
hostEnv = append(hostEnv, fmt.Sprintf("GF_PLUGIN_VERSION=%s", plugin.Info.Version))
}
hostEnv = append( hostEnv = append(
hostEnv, hostEnv,
fmt.Sprintf("GF_INSTANCE_OTLP_ADDRESS=%s", i.cfg.Opentelemetry.Address), fmt.Sprintf("GF_INSTANCE_OTLP_ADDRESS=%s", i.cfg.Opentelemetry.Address),

@ -132,53 +132,6 @@ func TestInitializer_Initialize(t *testing.T) {
} }
func TestInitializer_envVars(t *testing.T) { func TestInitializer_envVars(t *testing.T) {
t.Run("version", func(t *testing.T) {
for _, tc := range []struct {
name string
setup func(p *plugins.Plugin)
exp func(t *testing.T, i *Initializer, p *plugins.Plugin)
}{
{
name: "not provided",
setup: func(p *plugins.Plugin) {
p.Info = plugins.Info{}
},
exp: func(t *testing.T, i *Initializer, p *plugins.Plugin) {
for _, k := range i.envVars(p) {
if strings.HasPrefix("GF_PLUGIN_VERSION=", k) {
require.Fail(t, "found unexpected env var GF_PLUGIN_VERSION")
}
}
},
},
{
name: "provided",
setup: func(p *plugins.Plugin) {
p.Info = plugins.Info{Version: "0.1"}
},
exp: func(t *testing.T, i *Initializer, p *plugins.Plugin) {
require.Contains(t, i.envVars(p), "GF_PLUGIN_VERSION=0.1")
},
},
} {
t.Run(tc.name, func(t *testing.T) {
p := &plugins.Plugin{
JSONData: plugins.JSONData{
ID: "test",
Info: plugins.Info{Version: "0.1"},
},
}
tc.setup(p)
i := &Initializer{
cfg: &config.Cfg{},
log: log.NewTestLogger(),
backendProvider: &fakeBackendProvider{plugin: p},
}
tc.exp(t, i, p)
})
}
})
t.Run("backend datasource with license", func(t *testing.T) { t.Run("backend datasource with license", func(t *testing.T) {
p := &plugins.Plugin{ p := &plugins.Plugin{
JSONData: plugins.JSONData{ JSONData: plugins.JSONData{
@ -222,7 +175,13 @@ func TestInitializer_envVars(t *testing.T) {
func TestInitializer_tracingEnvironmentVariables(t *testing.T) { func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
const pluginID = "plugin_id" const pluginID = "plugin_id"
p := &plugins.Plugin{ defaultPlugin := &plugins.Plugin{
JSONData: plugins.JSONData{
ID: pluginID,
Info: plugins.Info{Version: "1.0.0"},
},
}
pluginWithoutVersion := &plugins.Plugin{
JSONData: plugins.JSONData{ID: pluginID}, JSONData: plugins.JSONData{ID: pluginID},
} }
@ -233,9 +192,9 @@ func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
expDefaultOtlp := func(t *testing.T, envVars []string) { expDefaultOtlp := func(t *testing.T, envVars []string) {
found := map[string]bool{ found := map[string]bool{
"address": false, "address": false,
"version": false, "plugin_version": false,
"propagation": false, "propagation": false,
} }
setFound := func(v string) { setFound := func(v string) {
require.False(t, found[v], "duplicate env var found") require.False(t, found[v], "duplicate env var found")
@ -243,8 +202,8 @@ func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
} }
for _, v := range envVars { for _, v := range envVars {
switch v { switch v {
case "GF_VERSION=": case "GF_PLUGIN_VERSION=1.0.0":
setFound("version") setFound("plugin_version")
case "GF_INSTANCE_OTLP_ADDRESS=127.0.0.1:4317": case "GF_INSTANCE_OTLP_ADDRESS=127.0.0.1:4317":
setFound("address") setFound("address")
case "GF_INSTANCE_OTLP_PROPAGATION=": case "GF_INSTANCE_OTLP_PROPAGATION=":
@ -252,48 +211,109 @@ func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
} }
} }
for k, f := range found { for k, f := range found {
require.Truef(t, f, "%q env var not found", k) require.Truef(t, f, "%q env var not found: %+v", k, envVars)
} }
} }
expNoTracing := func(t *testing.T, envVars []string) { expNoTracing := func(t *testing.T, envVars []string) {
for _, v := range envVars { for _, v := range envVars {
assert.False(t, strings.HasPrefix(v, "GF_TRACING"), "should not have tracing env var") assert.False(t, strings.HasPrefix(v, "GF_TRACING"), "should not have tracing env var")
assert.False(
t,
strings.HasPrefix(v, "GF_PLUGIN_VERSION"),
"GF_PLUGIN_VERSION is tracing-only and should not be present when tracing is disabled",
)
} }
} }
expGfPluginVersionNotPresent := func(t *testing.T, envVars []string) {
for _, e := range envVars {
assert.False(t, strings.HasPrefix("GF_PLUGIN_VERSION=", e), "GF_PLUGIN_VERSION shouldn't be present")
}
}
expGfPluginVersionPresent := func(t *testing.T, envVars []string) {
var found bool
for _, e := range envVars {
if e != "GF_PLUGIN_VERSION=1.0.0" {
continue
}
assert.False(t, found, "GF_PLUGIN_VERSION is present multiple times")
found = true
}
assert.Truef(t, found, "GF_PLUGIN_VERSION is not present: %+v", envVars)
}
for _, tc := range []struct { for _, tc := range []struct {
name string name string
cfg *config.Cfg cfg *config.Cfg
exp func(t *testing.T, envVars []string) plugin *plugins.Plugin
exp func(t *testing.T, envVars []string)
}{ }{
{ {
name: "disabled", name: "otel not configured",
cfg: &config.Cfg{ cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{}, Opentelemetry: config.OpentelemetryCfg{},
}, },
exp: expNoTracing, plugin: defaultPlugin,
exp: expNoTracing,
},
{
name: "otel not configured but plugin-tracing enabled",
cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{},
PluginSettings: map[string]map[string]string{pluginID: {"tracing": "true"}},
},
plugin: defaultPlugin,
exp: expNoTracing,
},
{
name: "otlp no propagation plugin enabled",
cfg: &config.Cfg{
Opentelemetry: defaultOtelCfg,
PluginSettings: map[string]map[string]string{
pluginID: {"tracing": "true"},
},
},
plugin: defaultPlugin,
exp: expDefaultOtlp,
}, },
{ {
name: "otlp no propagation", name: "otlp no propagation disabled by default",
cfg: &config.Cfg{ cfg: &config.Cfg{
Opentelemetry: defaultOtelCfg, Opentelemetry: defaultOtelCfg,
}, },
exp: expDefaultOtlp, plugin: defaultPlugin,
exp: expNoTracing,
}, },
{ {
name: "otlp propagation", name: "otlp propagation plugin enabled",
cfg: &config.Cfg{ cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{ Opentelemetry: config.OpentelemetryCfg{
Address: "127.0.0.1:4317", Address: "127.0.0.1:4317",
Propagation: "w3c", Propagation: "w3c",
}, },
PluginSettings: map[string]map[string]string{
pluginID: {"tracing": "true"},
},
}, },
plugin: defaultPlugin,
exp: func(t *testing.T, envVars []string) { exp: func(t *testing.T, envVars []string) {
assert.Len(t, envVars, 3) assert.Len(t, envVars, 5)
assert.Equal(t, "GF_VERSION=", envVars[0]) assert.Equal(t, "GF_PLUGIN_TRACING=true", envVars[0])
assert.Equal(t, "GF_INSTANCE_OTLP_ADDRESS=127.0.0.1:4317", envVars[1]) assert.Equal(t, "GF_VERSION=", envVars[1])
assert.Equal(t, "GF_INSTANCE_OTLP_PROPAGATION=w3c", envVars[2]) assert.Equal(t, "GF_PLUGIN_VERSION=1.0.0", envVars[2])
assert.Equal(t, "GF_INSTANCE_OTLP_ADDRESS=127.0.0.1:4317", envVars[3])
assert.Equal(t, "GF_INSTANCE_OTLP_PROPAGATION=w3c", envVars[4])
},
},
{
name: "otlp no propagation disabled by default",
cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{
Address: "127.0.0.1:4317",
Propagation: "w3c",
},
}, },
plugin: defaultPlugin,
exp: expNoTracing,
}, },
{ {
name: "disabled on plugin", name: "disabled on plugin",
@ -303,17 +323,57 @@ func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
pluginID: map[string]string{"tracing": "false"}, pluginID: map[string]string{"tracing": "false"},
}, },
}, },
exp: expNoTracing, plugin: defaultPlugin,
exp: expNoTracing,
}, },
{ {
name: "not disabled on plugin with other plugin settings", name: "disabled on plugin with other plugin settings",
cfg: &config.Cfg{ cfg: &config.Cfg{
Opentelemetry: defaultOtelCfg, Opentelemetry: defaultOtelCfg,
PluginSettings: map[string]map[string]string{ PluginSettings: map[string]map[string]string{
pluginID: {"some_other_option": "true"}, pluginID: {"some_other_option": "true"},
}, },
}, },
exp: expDefaultOtlp, plugin: defaultPlugin,
exp: expNoTracing,
},
{
name: "enabled on plugin with other plugin settings",
cfg: &config.Cfg{
Opentelemetry: defaultOtelCfg,
PluginSettings: map[string]map[string]string{
pluginID: {"some_other_option": "true", "tracing": "true"},
},
},
plugin: defaultPlugin,
exp: expDefaultOtlp,
},
{
name: "GF_PLUGIN_VERSION is not present if tracing is disabled",
cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{}, // no OTEL config
PluginSettings: map[string]map[string]string{pluginID: {"tracing": "true"}},
},
plugin: defaultPlugin,
exp: expGfPluginVersionNotPresent,
},
{
name: "GF_PLUGIN_VERSION is present if tracing is enabled and plugin has version",
cfg: &config.Cfg{
Opentelemetry: defaultOtelCfg,
PluginSettings: map[string]map[string]string{pluginID: {"tracing": "true"}},
},
plugin: defaultPlugin,
exp: expGfPluginVersionPresent,
},
{
name: "GF_PLUGIN_VERSION is not present if tracing is enabled but plugin doesn't have a version",
cfg: &config.Cfg{
Opentelemetry: config.OpentelemetryCfg{},
PluginSettings: map[string]map[string]string{pluginID: {"tracing": "true"}},
},
plugin: pluginWithoutVersion,
exp: expGfPluginVersionNotPresent,
}, },
} { } {
t.Run(tc.name, func(t *testing.T) { t.Run(tc.name, func(t *testing.T) {
@ -321,7 +381,7 @@ func TestInitializer_tracingEnvironmentVariables(t *testing.T) {
cfg: tc.cfg, cfg: tc.cfg,
log: log.NewTestLogger(), log: log.NewTestLogger(),
} }
envVars := i.envVars(p) envVars := i.envVars(tc.plugin)
tc.exp(t, envVars) tc.exp(t, envVars)
}) })
} }

Loading…
Cancel
Save