2019-05-30 23:11:13 +01:00
|
|
|
package cli
|
|
|
|
|
|
|
|
import (
|
|
|
|
"encoding/json"
|
|
|
|
"os"
|
|
|
|
"testing"
|
|
|
|
|
2020-01-29 22:40:43 +00:00
|
|
|
"github.com/micro/cli/v2"
|
2020-02-08 02:14:34 +03:00
|
|
|
"github.com/micro/go-micro/v2"
|
|
|
|
"github.com/micro/go-micro/v2/config"
|
2020-01-30 14:39:00 +03:00
|
|
|
"github.com/micro/go-micro/v2/config/cmd"
|
|
|
|
"github.com/micro/go-micro/v2/config/source"
|
2019-05-30 23:11:13 +01:00
|
|
|
)
|
|
|
|
|
2020-02-08 02:14:34 +03:00
|
|
|
func TestCliSourceDefault(t *testing.T) {
|
|
|
|
const expVal string = "flagvalue"
|
|
|
|
|
|
|
|
service := micro.NewService(
|
|
|
|
micro.Flags(
|
2020-02-08 02:45:32 +03:00
|
|
|
// to be able to run inside go test
|
2020-02-08 02:14:34 +03:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "test.timeout",
|
|
|
|
},
|
|
|
|
&cli.BoolFlag{
|
|
|
|
Name: "test.v",
|
|
|
|
},
|
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "test.run",
|
|
|
|
},
|
2020-02-08 02:45:32 +03:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "test.testlogfile",
|
|
|
|
},
|
2020-02-08 02:14:34 +03:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "flag",
|
|
|
|
Usage: "It changes something",
|
|
|
|
EnvVars: []string{"flag"},
|
|
|
|
Value: expVal,
|
|
|
|
},
|
|
|
|
),
|
|
|
|
)
|
|
|
|
var cliSrc source.Source
|
|
|
|
service.Init(
|
|
|
|
// Loads CLI configuration
|
|
|
|
micro.Action(func(c *cli.Context) error {
|
|
|
|
cliSrc = NewSource(
|
|
|
|
Context(c),
|
|
|
|
)
|
|
|
|
return nil
|
|
|
|
}),
|
|
|
|
)
|
|
|
|
|
|
|
|
config.Load(cliSrc)
|
|
|
|
if fval := config.Get("flag").String("default"); fval != expVal {
|
|
|
|
t.Fatalf("default flag value not loaded %v != %v", fval, expVal)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-05-30 23:11:13 +01:00
|
|
|
func test(t *testing.T, withContext bool) {
|
|
|
|
var src source.Source
|
|
|
|
|
|
|
|
// setup app
|
|
|
|
app := cmd.App()
|
|
|
|
app.Name = "testapp"
|
|
|
|
app.Flags = []cli.Flag{
|
2020-02-08 02:14:34 +03:00
|
|
|
&cli.StringFlag{
|
|
|
|
Name: "db-host",
|
|
|
|
EnvVars: []string{"db-host"},
|
|
|
|
Value: "myval",
|
|
|
|
},
|
2019-05-30 23:11:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// with context
|
|
|
|
if withContext {
|
|
|
|
// set action
|
2020-01-25 13:41:25 +03:00
|
|
|
app.Action = func(c *cli.Context) error {
|
2019-05-30 23:11:13 +01:00
|
|
|
src = WithContext(c)
|
2020-01-25 13:41:25 +03:00
|
|
|
return nil
|
2019-05-30 23:11:13 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
// run app
|
|
|
|
app.Run([]string{"run", "-db-host", "localhost"})
|
|
|
|
// no context
|
|
|
|
} else {
|
|
|
|
// set args
|
|
|
|
os.Args = []string{"run", "-db-host", "localhost"}
|
|
|
|
src = NewSource()
|
|
|
|
}
|
|
|
|
|
|
|
|
// test config
|
|
|
|
c, err := src.Read()
|
|
|
|
if err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
var actual map[string]interface{}
|
|
|
|
if err := json.Unmarshal(c.Data, &actual); err != nil {
|
|
|
|
t.Error(err)
|
|
|
|
}
|
|
|
|
|
|
|
|
actualDB := actual["db"].(map[string]interface{})
|
|
|
|
if actualDB["host"] != "localhost" {
|
|
|
|
t.Errorf("expected localhost, got %v", actualDB["name"])
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCliSource(t *testing.T) {
|
|
|
|
// without context
|
|
|
|
test(t, false)
|
|
|
|
}
|
|
|
|
|
|
|
|
func TestCliSourceWithContext(t *testing.T) {
|
|
|
|
// with context
|
|
|
|
test(t, true)
|
|
|
|
}
|