2020-02-06 20:42:46 -05:00
|
|
|
package env
|
|
|
|
|
|
|
|
|
|
import (
|
2020-04-19 18:13:48 +00:00
|
|
|
"context"
|
2020-02-06 20:42:46 -05:00
|
|
|
"fmt"
|
|
|
|
|
"testing"
|
|
|
|
|
|
2020-04-12 18:09:46 +00:00
|
|
|
"github.com/golang/mock/gomock"
|
|
|
|
|
"github.com/qdm12/golibs/logging/mock_logging"
|
2020-02-06 20:42:46 -05:00
|
|
|
"github.com/stretchr/testify/assert"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
func Test_FatalOnError(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
tests := map[string]struct {
|
|
|
|
|
err error
|
|
|
|
|
}{
|
|
|
|
|
"nil": {},
|
|
|
|
|
"err": {fmt.Errorf("error")},
|
|
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
var logged string
|
2020-05-02 13:05:09 +00:00
|
|
|
var canceled bool
|
2020-04-12 18:09:46 +00:00
|
|
|
mockCtrl := gomock.NewController(t)
|
|
|
|
|
defer mockCtrl.Finish()
|
|
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
2020-02-06 20:42:46 -05:00
|
|
|
if tc.err != nil {
|
2020-04-12 18:09:46 +00:00
|
|
|
logger.EXPECT().Error(tc.err).Do(func(err error) {
|
|
|
|
|
logged = err.Error()
|
|
|
|
|
}).Times(1)
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
2020-05-02 13:05:09 +00:00
|
|
|
e := &env{
|
|
|
|
|
logger: logger,
|
|
|
|
|
cancelContext: func() { canceled = true },
|
|
|
|
|
}
|
2020-02-06 20:42:46 -05:00
|
|
|
e.FatalOnError(tc.err)
|
|
|
|
|
if tc.err != nil {
|
|
|
|
|
assert.Equal(t, logged, tc.err.Error())
|
2020-05-02 13:05:09 +00:00
|
|
|
assert.True(t, canceled)
|
2020-02-06 20:42:46 -05:00
|
|
|
} else {
|
|
|
|
|
assert.Empty(t, logged)
|
2020-05-02 13:05:09 +00:00
|
|
|
assert.False(t, canceled)
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func Test_PrintVersion(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
tests := map[string]struct {
|
|
|
|
|
program string
|
|
|
|
|
commandVersion string
|
|
|
|
|
commandErr error
|
|
|
|
|
}{
|
|
|
|
|
"no data": {},
|
|
|
|
|
"data": {"binu", "2.3-5", nil},
|
|
|
|
|
"error": {"binu", "", fmt.Errorf("error")},
|
|
|
|
|
}
|
|
|
|
|
for name, tc := range tests {
|
|
|
|
|
tc := tc
|
|
|
|
|
t.Run(name, func(t *testing.T) {
|
|
|
|
|
t.Parallel()
|
|
|
|
|
var logged string
|
2020-04-12 18:09:46 +00:00
|
|
|
mockCtrl := gomock.NewController(t)
|
|
|
|
|
defer mockCtrl.Finish()
|
|
|
|
|
logger := mock_logging.NewMockLogger(mockCtrl)
|
2020-02-06 20:42:46 -05:00
|
|
|
if tc.commandErr != nil {
|
2020-04-12 18:09:46 +00:00
|
|
|
logger.EXPECT().Error(tc.commandErr).Do(func(err error) {
|
|
|
|
|
logged = err.Error()
|
|
|
|
|
}).Times(1)
|
2020-02-06 20:42:46 -05:00
|
|
|
} else {
|
2020-04-12 18:09:46 +00:00
|
|
|
logger.EXPECT().Info("%s version: %s", tc.program, tc.commandVersion).
|
|
|
|
|
Do(func(format, program, version string) {
|
2020-02-06 20:42:46 -05:00
|
|
|
logged = fmt.Sprintf(format, program, version)
|
2020-04-12 18:09:46 +00:00
|
|
|
}).Times(1)
|
2020-02-06 20:42:46 -05:00
|
|
|
}
|
|
|
|
|
e := &env{logger: logger}
|
2020-04-19 18:13:48 +00:00
|
|
|
commandFn := func(ctx context.Context) (string, error) { return tc.commandVersion, tc.commandErr }
|
|
|
|
|
e.PrintVersion(context.Background(), tc.program, commandFn)
|
2020-02-06 20:42:46 -05:00
|
|
|
if tc.commandErr != nil {
|
|
|
|
|
assert.Equal(t, logged, tc.commandErr.Error())
|
|
|
|
|
} else {
|
|
|
|
|
assert.Equal(t, logged, fmt.Sprintf("%s version: %s", tc.program, tc.commandVersion))
|
|
|
|
|
}
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|