diff options
author | Valery Piashchynski <[email protected]> | 2021-02-16 00:04:05 +0300 |
---|---|---|
committer | Valery Piashchynski <[email protected]> | 2021-02-16 00:04:05 +0300 |
commit | 87b3130a95e2ff2904e7910f9bc87bc3020dbe27 (patch) | |
tree | cc08fda6ccdc56ec26b0ef39f2fa80d6b950086a /tests/plugins/config/config_test.go | |
parent | f8dd689d3b7c9f953d21775110f7d3182768cfba (diff) |
Add support for flag overwriting
Signed-off-by: Valery Piashchynski <[email protected]>
Diffstat (limited to 'tests/plugins/config/config_test.go')
-rwxr-xr-x | tests/plugins/config/config_test.go | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/tests/plugins/config/config_test.go b/tests/plugins/config/config_test.go index 364960db..609b62ef 100755 --- a/tests/plugins/config/config_test.go +++ b/tests/plugins/config/config_test.go @@ -8,6 +8,8 @@ import ( endure "github.com/spiral/endure/pkg/container" "github.com/spiral/roadrunner/v2/plugins/config" + "github.com/spiral/roadrunner/v2/plugins/logger" + "github.com/spiral/roadrunner/v2/plugins/rpc" "github.com/stretchr/testify/assert" ) @@ -62,3 +64,73 @@ func TestViperProvider_Init(t *testing.T) { } } } + +func TestConfigOverwriteFail(t *testing.T) { + container, err := endure.NewContainer(nil, endure.RetryOnFail(false), endure.SetLogLevel(endure.ErrorLevel)) + if err != nil { + t.Fatal(err) + } + vp := &config.Viper{} + vp.Path = ".rr.yaml" + vp.Prefix = "rr" + vp.Flags = []string{"rpc.listen=tcp//not_exist"} + + err = container.RegisterAll( + &logger.ZapLogger{}, + &rpc.Plugin{}, + vp, + &Foo2{}, + ) + assert.NoError(t, err) + + err = container.Init() + assert.Error(t, err) +} + +func TestConfigOverwriteValid(t *testing.T) { + container, err := endure.NewContainer(nil, endure.RetryOnFail(false), endure.SetLogLevel(endure.ErrorLevel)) + if err != nil { + t.Fatal(err) + } + vp := &config.Viper{} + vp.Path = ".rr.yaml" + vp.Prefix = "rr" + vp.Flags = []string{"rpc.listen=tcp://localhost:6061"} + + err = container.RegisterAll( + &logger.ZapLogger{}, + &rpc.Plugin{}, + vp, + &Foo2{}, + ) + assert.NoError(t, err) + + err = container.Init() + assert.NoError(t, err) + + errCh, err := container.Serve() + assert.NoError(t, err) + + // stop by CTRL+C + c := make(chan os.Signal, 1) + signal.Notify(c, os.Interrupt) + + tt := time.NewTicker(time.Second * 3) + defer tt.Stop() + + for { + select { + case e := <-errCh: + assert.NoError(t, e.Error) + assert.NoError(t, container.Stop()) + return + case <-c: + er := container.Stop() + assert.NoError(t, er) + return + case <-tt.C: + assert.NoError(t, container.Stop()) + return + } + } +} |