From 53f27d460b09cb877bdfd8412f6596a1e7239642 Mon Sep 17 00:00:00 2001 From: Kevin Conaway Date: Mon, 8 Oct 2018 10:35:02 -0400 Subject: [PATCH] Issue #3911: Expose telegraf agent version in internal module --- cmd/telegraf/telegraf.go | 5 +++++ internal/internal.go | 19 +++++++++++++++++++ internal/internal_test.go | 12 ++++++++++++ 3 files changed, 36 insertions(+) diff --git a/cmd/telegraf/telegraf.go b/cmd/telegraf/telegraf.go index 93336ffb4f44b..9b369372d00c6 100644 --- a/cmd/telegraf/telegraf.go +++ b/cmd/telegraf/telegraf.go @@ -326,6 +326,11 @@ func main() { return } + // Configure version + if err := internal.SetVersion(formatFullVersion()); err != nil { + log.Println("Telegraf version already configured to: " + internal.Version()) + } + if runtime.GOOS == "windows" && !(*fRunAsConsole) { svcConfig := &service.Config{ Name: *fServiceName, diff --git a/internal/internal.go b/internal/internal.go index f7d75dfb3a301..2247fa25d8165 100644 --- a/internal/internal.go +++ b/internal/internal.go @@ -22,13 +22,32 @@ var ( TimeoutErr = errors.New("Command timed out.") NotImplementedError = errors.New("not implemented yet") + + VersionAlreadySetError = errors.New("version has already been set") ) +// Set via the main module +var version string + // Duration just wraps time.Duration type Duration struct { Duration time.Duration } +// SetVersion sets the telegraf agent version +func SetVersion(v string) error { + if version != "" { + return VersionAlreadySetError + } + version = v + return nil +} + +// Version returns the telegraf agent version +func Version() string { + return version +} + // UnmarshalTOML parses the duration from the TOML config file func (d *Duration) UnmarshalTOML(b []byte) error { var err error diff --git a/internal/internal_test.go b/internal/internal_test.go index ee1d24418ad18..36475ecc53d36 100644 --- a/internal/internal_test.go +++ b/internal/internal_test.go @@ -162,3 +162,15 @@ func TestDuration(t *testing.T) { d.UnmarshalTOML([]byte(`1.5`)) assert.Equal(t, time.Second, d.Duration) } + +func TestVersionAlreadySet(t *testing.T) { + err := SetVersion("foo") + assert.Nil(t, err) + + err = SetVersion("bar") + + assert.NotNil(t, err) + assert.IsType(t, VersionAlreadySetError, err) + + assert.Equal(t, "foo", Version()) +}