From af707e7d4d7a8fad98872e2a902e056155ad9591 Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Thu, 29 Apr 2021 19:26:35 +0300 Subject: - Add new interface to obtain all plugins Signed-off-by: Valery Piashchynski --- go.mod | 4 ++++ plugins/informer/interface.go | 6 ++++++ plugins/informer/plugin.go | 20 +++++++++++++------- 3 files changed, 23 insertions(+), 7 deletions(-) diff --git a/go.mod b/go.mod index 12ef7b96..7991d130 100644 --- a/go.mod +++ b/go.mod @@ -35,3 +35,7 @@ require ( golang.org/x/sync v0.0.0-20201207232520-09787c993a3a golang.org/x/sys v0.0.0-20210309074719-68d13333faf2 ) + +replace ( + github.com/spiral/endure v1.0.1 => ../endure +) diff --git a/plugins/informer/interface.go b/plugins/informer/interface.go index 45f44691..cd8ab232 100644 --- a/plugins/informer/interface.go +++ b/plugins/informer/interface.go @@ -8,3 +8,9 @@ import ( type Informer interface { Workers() []process.State } + +// Lister interface used to filter available plugins +type Lister interface { + // List gets no args, but returns list of the active plugins + List() []string +} diff --git a/plugins/informer/plugin.go b/plugins/informer/plugin.go index 98081d34..3d219cda 100644 --- a/plugins/informer/plugin.go +++ b/plugins/informer/plugin.go @@ -11,6 +11,7 @@ const PluginName = "informer" type Plugin struct { registry map[string]Informer + plugins map[string]Lister log logger.Logger } @@ -31,19 +32,24 @@ func (p *Plugin) Workers(name string) ([]process.State, error) { return svc.Workers(), nil } -// CollectTarget resettable service. -func (p *Plugin) CollectTarget(name endure.Named, r Informer) error { - p.registry[name.Name()] = r - return nil -} - // Collects declares services to be collected. func (p *Plugin) Collects() []interface{} { return []interface{}{ - p.CollectTarget, + p.CollectWorkers, } } +// CollectPlugins collects all RR plugins +func (p *Plugin) CollectPlugins(name endure.Named, l Lister) { + p.plugins[name.Name()] = l +} + +// CollectWorkers obtains plugins with workers inside. +func (p *Plugin) CollectWorkers(name endure.Named, r Informer) error { + p.registry[name.Name()] = r + return nil +} + // Name of the service. func (p *Plugin) Name() string { return PluginName -- cgit v1.2.3 From 65015a3d3f4b387675b5ca005b8831a6be9e15aa Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Fri, 30 Apr 2021 01:14:05 +0300 Subject: - Remove local go.mod replace Signed-off-by: Valery Piashchynski --- go.mod | 4 ---- 1 file changed, 4 deletions(-) diff --git a/go.mod b/go.mod index 7991d130..12ef7b96 100644 --- a/go.mod +++ b/go.mod @@ -35,7 +35,3 @@ require ( golang.org/x/sync v0.0.0-20201207232520-09787c993a3a golang.org/x/sys v0.0.0-20210309074719-68d13333faf2 ) - -replace ( - github.com/spiral/endure v1.0.1 => ../endure -) -- cgit v1.2.3 From 50aa751dcefc0ab0e96594a5f111ead316a34a70 Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Fri, 30 Apr 2021 11:44:07 +0300 Subject: - Update Lister implementation Signed-off-by: Valery Piashchynski --- plugins/config/plugin.go | 7 ++++++- plugins/gzip/plugin.go | 7 ++++++- plugins/headers/plugin.go | 11 ++++++++--- plugins/http/plugin.go | 5 +++++ plugins/informer/interface.go | 13 +++++++++---- plugins/informer/plugin.go | 20 +++++++++----------- plugins/informer/rpc.go | 11 ++--------- plugins/kv/config.go | 1 + plugins/kv/drivers/boltdb/plugin.go | 5 +++++ plugins/kv/drivers/memcached/plugin.go | 5 +++++ plugins/kv/drivers/memory/plugin.go | 5 +++++ plugins/kv/storage.go | 5 +++++ 12 files changed, 66 insertions(+), 29 deletions(-) diff --git a/plugins/config/plugin.go b/plugins/config/plugin.go index 58647eb8..eb7146b2 100755 --- a/plugins/config/plugin.go +++ b/plugins/config/plugin.go @@ -113,11 +113,16 @@ func (v *Viper) Has(name string) bool { return v.viper.IsSet(name) } -// Returns common config parameters +// GetCommonConfig Returns common config parameters func (v *Viper) GetCommonConfig() *General { return v.CommonConfig } +// Available interface implementation +func (v *Viper) Available() bool { + return true +} + func parseFlag(flag string) (string, string, error) { const op = errors.Op("parse_flag") if !strings.Contains(flag, "=") { diff --git a/plugins/gzip/plugin.go b/plugins/gzip/plugin.go index 18ee7b88..d25894ff 100644 --- a/plugins/gzip/plugin.go +++ b/plugins/gzip/plugin.go @@ -10,7 +10,7 @@ const PluginName = "gzip" type Plugin struct{} -// needed for the Endure +// Init needed for the Endure func (g *Plugin) Init() error { return nil } @@ -21,6 +21,11 @@ func (g *Plugin) Middleware(next http.Handler) http.Handler { }) } +// Available interface implementation +func (g *Plugin) Available() bool { + return true +} + func (g *Plugin) Name() string { return PluginName } diff --git a/plugins/headers/plugin.go b/plugins/headers/plugin.go index dea0d127..caba6aeb 100644 --- a/plugins/headers/plugin.go +++ b/plugins/headers/plugin.go @@ -8,11 +8,11 @@ import ( "github.com/spiral/roadrunner/v2/plugins/config" ) -// ID contains default service name. +// PluginName contains default service name. const PluginName = "headers" const RootPluginName = "http" -// Service serves headers files. Potentially convert into middleware? +// Plugin serves headers files. Potentially convert into middleware? type Plugin struct { // server configuration (location, forbidden files and etc) cfg *Config @@ -37,7 +37,7 @@ func (s *Plugin) Init(cfg config.Configurer) error { return nil } -// middleware must return true if request/response pair is handled within the middleware. +// Middleware is HTTP plugin middleware to serve headers func (s *Plugin) Middleware(next http.Handler) http.Handler { // Define the http.HandlerFunc return http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { @@ -69,6 +69,11 @@ func (s *Plugin) Name() string { return PluginName } +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} + // configure OPTIONS response func (s *Plugin) preflightRequest(w http.ResponseWriter) { headers := w.Header() diff --git a/plugins/http/plugin.go b/plugins/http/plugin.go index 2b1dec89..cf6d75fd 100644 --- a/plugins/http/plugin.go +++ b/plugins/http/plugin.go @@ -440,3 +440,8 @@ func (s *Plugin) Ready() status.Status { Code: http.StatusServiceUnavailable, } } + +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} diff --git a/plugins/informer/interface.go b/plugins/informer/interface.go index cd8ab232..08eda00b 100644 --- a/plugins/informer/interface.go +++ b/plugins/informer/interface.go @@ -4,13 +4,18 @@ import ( "github.com/spiral/roadrunner/v2/pkg/process" ) +/* +Informer plugin should not receive any other plugin in the Init or via Collects +Because Availabler implementation should present in every plugin +*/ + // Informer used to get workers from particular plugin or set of plugins type Informer interface { Workers() []process.State } -// Lister interface used to filter available plugins -type Lister interface { - // List gets no args, but returns list of the active plugins - List() []string +// Availabler interface should be implemented by every plugin which wish to report to the PHP worker that it available in the RR runtime +type Availabler interface { + // Available returns true if the particular plugin available in the RR2 runtime + Available() bool } diff --git a/plugins/informer/plugin.go b/plugins/informer/plugin.go index 3d219cda..73e49575 100644 --- a/plugins/informer/plugin.go +++ b/plugins/informer/plugin.go @@ -4,20 +4,18 @@ import ( endure "github.com/spiral/endure/pkg/container" "github.com/spiral/errors" "github.com/spiral/roadrunner/v2/pkg/process" - "github.com/spiral/roadrunner/v2/plugins/logger" ) const PluginName = "informer" type Plugin struct { - registry map[string]Informer - plugins map[string]Lister - log logger.Logger + registry map[string]Informer + available map[string]Availabler } -func (p *Plugin) Init(log logger.Logger) error { +func (p *Plugin) Init() error { + p.available = make(map[string]Availabler) p.registry = make(map[string]Informer) - p.log = log return nil } @@ -36,18 +34,18 @@ func (p *Plugin) Workers(name string) ([]process.State, error) { func (p *Plugin) Collects() []interface{} { return []interface{}{ p.CollectWorkers, + p.CollectPlugins, } } // CollectPlugins collects all RR plugins -func (p *Plugin) CollectPlugins(name endure.Named, l Lister) { - p.plugins[name.Name()] = l +func (p *Plugin) CollectPlugins(name endure.Named, l Availabler) { + p.available[name.Name()] = l } // CollectWorkers obtains plugins with workers inside. -func (p *Plugin) CollectWorkers(name endure.Named, r Informer) error { +func (p *Plugin) CollectWorkers(name endure.Named, r Informer) { p.registry[name.Name()] = r - return nil } // Name of the service. @@ -57,5 +55,5 @@ func (p *Plugin) Name() string { // RPC returns associated rpc service. func (p *Plugin) RPC() interface{} { - return &rpc{srv: p, log: p.log} + return &rpc{srv: p} } diff --git a/plugins/informer/rpc.go b/plugins/informer/rpc.go index b0b5b1af..8955af92 100644 --- a/plugins/informer/rpc.go +++ b/plugins/informer/rpc.go @@ -2,12 +2,10 @@ package informer import ( "github.com/spiral/roadrunner/v2/pkg/process" - "github.com/spiral/roadrunner/v2/plugins/logger" ) type rpc struct { srv *Plugin - log logger.Logger } // WorkerList contains list of workers. @@ -18,20 +16,17 @@ type WorkerList struct { // List all resettable services. func (rpc *rpc) List(_ bool, list *[]string) error { - rpc.log.Debug("Started List method") *list = make([]string, 0, len(rpc.srv.registry)) - for name := range rpc.srv.registry { + // append all plugin names to the output result + for name := range rpc.srv.available { *list = append(*list, name) } - rpc.log.Debug("list of services", "list", *list) - rpc.log.Debug("successfully finished List method") return nil } // Workers state of a given service. func (rpc *rpc) Workers(service string, list *WorkerList) error { - rpc.log.Debug("started Workers method", "service", service) workers, err := rpc.srv.Workers(service) if err != nil { return err @@ -40,7 +35,5 @@ func (rpc *rpc) Workers(service string, list *WorkerList) error { // write actual processes list.Workers = workers - rpc.log.Debug("list of workers", "workers", list.Workers) - rpc.log.Debug("successfully finished Workers method") return nil } diff --git a/plugins/kv/config.go b/plugins/kv/config.go index 9ecae644..66095817 100644 --- a/plugins/kv/config.go +++ b/plugins/kv/config.go @@ -1,5 +1,6 @@ package kv +// Config represents general storage configuration with keys as the user defined kv-names and values as the drivers type Config struct { Data map[string]interface{} `mapstructure:"kv"` } diff --git a/plugins/kv/drivers/boltdb/plugin.go b/plugins/kv/drivers/boltdb/plugin.go index 9d1e0dba..eba388c2 100644 --- a/plugins/kv/drivers/boltdb/plugin.go +++ b/plugins/kv/drivers/boltdb/plugin.go @@ -63,3 +63,8 @@ func (s *Plugin) Provide(key string) (kv.Storage, error) { func (s *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} diff --git a/plugins/kv/drivers/memcached/plugin.go b/plugins/kv/drivers/memcached/plugin.go index af59e91b..c95a7f73 100644 --- a/plugins/kv/drivers/memcached/plugin.go +++ b/plugins/kv/drivers/memcached/plugin.go @@ -33,6 +33,11 @@ func (s *Plugin) Name() string { return PluginName } +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} + func (s *Plugin) Provide(key string) (kv.Storage, error) { const op = errors.Op("boltdb_plugin_provide") st, err := NewMemcachedDriver(s.log, key, s.cfgPlugin) diff --git a/plugins/kv/drivers/memory/plugin.go b/plugins/kv/drivers/memory/plugin.go index acc6023d..fd4ed15f 100644 --- a/plugins/kv/drivers/memory/plugin.go +++ b/plugins/kv/drivers/memory/plugin.go @@ -62,3 +62,8 @@ func (s *Plugin) Provide(key string) (kv.Storage, error) { func (s *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} diff --git a/plugins/kv/storage.go b/plugins/kv/storage.go index e8468b77..2f1e0716 100644 --- a/plugins/kv/storage.go +++ b/plugins/kv/storage.go @@ -184,3 +184,8 @@ func (p *Plugin) RPC() interface{} { func (p *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (p *Plugin) Available() bool { + return true +} -- cgit v1.2.3 From d0dccb0c761df45da7fba00340f1cd5c66c71711 Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Fri, 30 Apr 2021 13:09:18 +0300 Subject: - Add Availabler interface implementaion for all plugins - Add tests Signed-off-by: Valery Piashchynski --- plugins/config/plugin.go | 15 +++++++++++++++ plugins/informer/plugin.go | 2 +- plugins/logger/plugin.go | 10 ++++++++++ plugins/metrics/plugin.go | 5 +++++ plugins/redis/plugin.go | 5 +++++ plugins/reload/plugin.go | 5 +++++ plugins/resetter/plugin.go | 5 +++++ plugins/rpc/plugin.go | 5 +++++ plugins/server/plugin.go | 5 +++++ plugins/service/plugin.go | 5 +++++ plugins/status/plugin.go | 7 ++++++- tests/plugins/informer/informer_test.go | 11 +++++------ tests/plugins/informer/test_plugin.go | 4 ++++ 13 files changed, 76 insertions(+), 8 deletions(-) diff --git a/plugins/config/plugin.go b/plugins/config/plugin.go index eb7146b2..a5215226 100755 --- a/plugins/config/plugin.go +++ b/plugins/config/plugin.go @@ -10,6 +10,8 @@ import ( "github.com/spiral/errors" ) +const PluginName string = "config" + type Viper struct { viper *viper.Viper Path string @@ -118,6 +120,19 @@ func (v *Viper) GetCommonConfig() *General { return v.CommonConfig } +func (v *Viper) Serve() chan error { + return make(chan error, 1) +} + +func (v *Viper) Stop() error { + return nil +} + +// Name returns user-friendly plugin name +func (v *Viper) Name() string { + return PluginName +} + // Available interface implementation func (v *Viper) Available() bool { return true diff --git a/plugins/informer/plugin.go b/plugins/informer/plugin.go index 73e49575..2d76123b 100644 --- a/plugins/informer/plugin.go +++ b/plugins/informer/plugin.go @@ -33,8 +33,8 @@ func (p *Plugin) Workers(name string) ([]process.State, error) { // Collects declares services to be collected. func (p *Plugin) Collects() []interface{} { return []interface{}{ - p.CollectWorkers, p.CollectPlugins, + p.CollectWorkers, } } diff --git a/plugins/logger/plugin.go b/plugins/logger/plugin.go index e1066cba..86275a85 100644 --- a/plugins/logger/plugin.go +++ b/plugins/logger/plugin.go @@ -81,3 +81,13 @@ func (z *ZapLogger) Provides() []interface{} { z.DefaultLogger, } } + +// Name returns user-friendly plugin name +func (z *ZapLogger) Name() string { + return PluginName +} + +// Available interface implementation +func (z *ZapLogger) Available() bool { + return true +} diff --git a/plugins/metrics/plugin.go b/plugins/metrics/plugin.go index d0443177..df6ea122 100644 --- a/plugins/metrics/plugin.go +++ b/plugins/metrics/plugin.go @@ -222,3 +222,8 @@ func (m *Plugin) RPC() interface{} { log: m.log, } } + +// Available interface implementation +func (m *Plugin) Available() bool { + return true +} diff --git a/plugins/redis/plugin.go b/plugins/redis/plugin.go index 204abd17..b69af9d6 100644 --- a/plugins/redis/plugin.go +++ b/plugins/redis/plugin.go @@ -76,3 +76,8 @@ func (s Plugin) Stop() error { func (s *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} diff --git a/plugins/reload/plugin.go b/plugins/reload/plugin.go index bf88462e..d2c22fe8 100644 --- a/plugins/reload/plugin.go +++ b/plugins/reload/plugin.go @@ -161,3 +161,8 @@ func (s *Plugin) Stop() error { func (s *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} diff --git a/plugins/resetter/plugin.go b/plugins/resetter/plugin.go index 43382e56..a80c2c0f 100644 --- a/plugins/resetter/plugin.go +++ b/plugins/resetter/plugin.go @@ -74,6 +74,11 @@ func (p *Plugin) Name() string { return PluginName } +// Available interface implementation +func (p *Plugin) Available() bool { + return true +} + // RPC returns associated rpc service. func (p *Plugin) RPC() interface{} { return &rpc{srv: p, log: p.log} diff --git a/plugins/rpc/plugin.go b/plugins/rpc/plugin.go index b80994d3..f88aa6de 100644 --- a/plugins/rpc/plugin.go +++ b/plugins/rpc/plugin.go @@ -122,6 +122,11 @@ func (s *Plugin) Name() string { return PluginName } +// Available interface implementation +func (s *Plugin) Available() bool { + return true +} + // Collects all plugins which implement Name + RPCer interfaces func (s *Plugin) Collects() []interface{} { return []interface{}{ diff --git a/plugins/server/plugin.go b/plugins/server/plugin.go index c3496ae7..64793034 100644 --- a/plugins/server/plugin.go +++ b/plugins/server/plugin.go @@ -58,6 +58,11 @@ func (server *Plugin) Name() string { return PluginName } +// Available interface implementation +func (server *Plugin) Available() bool { + return true +} + // Serve (Start) server plugin (just a mock here to satisfy interface) func (server *Plugin) Serve() chan error { const op = errors.Op("server_plugin_serve") diff --git a/plugins/service/plugin.go b/plugins/service/plugin.go index b5608ff2..522fe192 100644 --- a/plugins/service/plugin.go +++ b/plugins/service/plugin.go @@ -104,3 +104,8 @@ func (service *Plugin) Stop() error { func (service *Plugin) Name() string { return PluginName } + +// Available interface implementation +func (service *Plugin) Available() bool { + return true +} diff --git a/plugins/status/plugin.go b/plugins/status/plugin.go index dc4e506d..3553bb01 100644 --- a/plugins/status/plugin.go +++ b/plugins/status/plugin.go @@ -127,7 +127,12 @@ func (c *Plugin) Name() string { return PluginName } -// RPCService returns associated rpc service. +// Available interface implementation +func (c *Plugin) Available() bool { + return true +} + +// RPC returns associated rpc service. func (c *Plugin) RPC() interface{} { return &rpc{srv: c, log: c.log} } diff --git a/tests/plugins/informer/informer_test.go b/tests/plugins/informer/informer_test.go index b6f50fd5..d40d7093 100644 --- a/tests/plugins/informer/informer_test.go +++ b/tests/plugins/informer/informer_test.go @@ -64,10 +64,7 @@ func TestInformerInit(t *testing.T) { select { case e := <-ch: assert.Fail(t, "error", e.Error.Error()) - err = cont.Stop() - if err != nil { - assert.FailNow(t, "error", err.Error()) - } + return case <-sig: err = cont.Stop() if err != nil { @@ -113,9 +110,11 @@ func informerListRPCTest(t *testing.T) { assert.NoError(t, err) client := rpc.NewClientWithCodec(goridgeRpc.NewClientCodec(conn)) // WorkerList contains list of workers. - list := make([]string, 0, 0) + list := make([]string, 0, 5) + // Plugins which are expected to be in the list + expected := []string{"rpc", "logs", "informer.plugin1", "config", "server"} err = client.Call("informer.List", true, &list) assert.NoError(t, err) - assert.Equal(t, "informer.plugin1", list[0]) + assert.ElementsMatch(t, list, expected) } diff --git a/tests/plugins/informer/test_plugin.go b/tests/plugins/informer/test_plugin.go index 0c9065a3..db757110 100644 --- a/tests/plugins/informer/test_plugin.go +++ b/tests/plugins/informer/test_plugin.go @@ -49,6 +49,10 @@ func (p1 *Plugin1) Name() string { return "informer.plugin1" } +func (p1 *Plugin1) Available() bool { + return true +} + func (p1 *Plugin1) Workers() []process.State { p, err := p1.server.NewWorkerPool(context.Background(), testPoolConfig, nil) if err != nil { -- cgit v1.2.3 From 5f451ffbba6b9758d61ba70ddd112a8e1570045a Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Fri, 30 Apr 2021 13:41:18 +0300 Subject: - Update CHANGELOG Signed-off-by: Valery Piashchynski --- CHANGELOG.md | 5 ++++- Makefile | 3 --- plugins/config/plugin.go | 4 +--- plugins/gzip/plugin.go | 4 +--- plugins/headers/plugin.go | 4 +--- plugins/http/plugin.go | 4 +--- plugins/informer/interface.go | 4 ++-- plugins/kv/drivers/boltdb/plugin.go | 4 +--- plugins/kv/drivers/memcached/plugin.go | 4 +--- plugins/kv/drivers/memory/plugin.go | 3 +-- plugins/kv/storage.go | 3 +-- plugins/logger/plugin.go | 3 +-- plugins/metrics/plugin.go | 3 +-- plugins/redis/plugin.go | 3 +-- plugins/reload/plugin.go | 3 +-- plugins/resetter/plugin.go | 3 +-- plugins/rpc/plugin.go | 3 +-- plugins/server/plugin.go | 3 +-- plugins/service/plugin.go | 3 +-- plugins/status/plugin.go | 4 +--- tests/plugins/informer/test_plugin.go | 4 +--- 21 files changed, 24 insertions(+), 50 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 57d17096..3ed7c7bb 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -13,12 +13,15 @@ v2.2.0 (11.05.2021) , `weak` and `pattern`. ### Option `always` was deleted from the plugin. -- ✏️ + +- ✏️ Update `informer.List` implementation. Now it returns a list with the all available plugins in the runtime. ## 🩹 Fixes: - 🐛 Fix: issue with wrong ordered middlewares (reverse). Now the order is correct. +--- + v2.1.1 (29.04.2021) ------------------- diff --git a/Makefile b/Makefile index 8cce149a..2d14a101 100755 --- a/Makefile +++ b/Makefile @@ -47,9 +47,6 @@ test_coverage: go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/redis.out -covermode=atomic ./tests/plugins/redis go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/resetter.out -covermode=atomic ./tests/plugins/resetter go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/rpc.out -covermode=atomic ./tests/plugins/rpc - go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/boltdb.out -covermode=atomic ./tests/plugins/kv/boltdb - go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/memory.out -covermode=atomic ./tests/plugins/kv/memory - go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/memcached.out -covermode=atomic ./tests/plugins/kv/memcached go test -v -race -cover -tags=debug -coverpkg=./... -coverprofile=./coverage/kv_plugin.out -covermode=atomic ./tests/plugins/kv cat ./coverage/*.out > ./coverage/summary.out docker-compose -f tests/docker-compose.yaml down diff --git a/plugins/config/plugin.go b/plugins/config/plugin.go index a5215226..918381c4 100755 --- a/plugins/config/plugin.go +++ b/plugins/config/plugin.go @@ -134,9 +134,7 @@ func (v *Viper) Name() string { } // Available interface implementation -func (v *Viper) Available() bool { - return true -} +func (v *Viper) Available() {} func parseFlag(flag string) (string, string, error) { const op = errors.Op("parse_flag") diff --git a/plugins/gzip/plugin.go b/plugins/gzip/plugin.go index d25894ff..24b125fb 100644 --- a/plugins/gzip/plugin.go +++ b/plugins/gzip/plugin.go @@ -22,9 +22,7 @@ func (g *Plugin) Middleware(next http.Handler) http.Handler { } // Available interface implementation -func (g *Plugin) Available() bool { - return true -} +func (g *Plugin) Available() {} func (g *Plugin) Name() string { return PluginName diff --git a/plugins/headers/plugin.go b/plugins/headers/plugin.go index caba6aeb..19c444df 100644 --- a/plugins/headers/plugin.go +++ b/plugins/headers/plugin.go @@ -70,9 +70,7 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true -} +func (s *Plugin) Available() {} // configure OPTIONS response func (s *Plugin) preflightRequest(w http.ResponseWriter) { diff --git a/plugins/http/plugin.go b/plugins/http/plugin.go index cf6d75fd..344102f4 100644 --- a/plugins/http/plugin.go +++ b/plugins/http/plugin.go @@ -442,6 +442,4 @@ func (s *Plugin) Ready() status.Status { } // Available interface implementation -func (s *Plugin) Available() bool { - return true -} +func (s *Plugin) Available() {} diff --git a/plugins/informer/interface.go b/plugins/informer/interface.go index 08eda00b..316c7bc1 100644 --- a/plugins/informer/interface.go +++ b/plugins/informer/interface.go @@ -16,6 +16,6 @@ type Informer interface { // Availabler interface should be implemented by every plugin which wish to report to the PHP worker that it available in the RR runtime type Availabler interface { - // Available returns true if the particular plugin available in the RR2 runtime - Available() bool + // Available method needed to collect all plugins which are available in the runtime. + Available() } diff --git a/plugins/kv/drivers/boltdb/plugin.go b/plugins/kv/drivers/boltdb/plugin.go index eba388c2..9b4cf9f7 100644 --- a/plugins/kv/drivers/boltdb/plugin.go +++ b/plugins/kv/drivers/boltdb/plugin.go @@ -65,6 +65,4 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true -} +func (s *Plugin) Available() {} diff --git a/plugins/kv/drivers/memcached/plugin.go b/plugins/kv/drivers/memcached/plugin.go index c95a7f73..cde84f42 100644 --- a/plugins/kv/drivers/memcached/plugin.go +++ b/plugins/kv/drivers/memcached/plugin.go @@ -34,9 +34,7 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true -} +func (s *Plugin) Available() {} func (s *Plugin) Provide(key string) (kv.Storage, error) { const op = errors.Op("boltdb_plugin_provide") diff --git a/plugins/kv/drivers/memory/plugin.go b/plugins/kv/drivers/memory/plugin.go index fd4ed15f..2be7caae 100644 --- a/plugins/kv/drivers/memory/plugin.go +++ b/plugins/kv/drivers/memory/plugin.go @@ -64,6 +64,5 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true +func (s *Plugin) Available() { } diff --git a/plugins/kv/storage.go b/plugins/kv/storage.go index 2f1e0716..fe2fa10b 100644 --- a/plugins/kv/storage.go +++ b/plugins/kv/storage.go @@ -186,6 +186,5 @@ func (p *Plugin) Name() string { } // Available interface implementation -func (p *Plugin) Available() bool { - return true +func (p *Plugin) Available() { } diff --git a/plugins/logger/plugin.go b/plugins/logger/plugin.go index 1084cc5e..ffbf7f5e 100644 --- a/plugins/logger/plugin.go +++ b/plugins/logger/plugin.go @@ -82,6 +82,5 @@ func (z *ZapLogger) Name() string { } // Available interface implementation -func (z *ZapLogger) Available() bool { - return true +func (z *ZapLogger) Available() { } diff --git a/plugins/metrics/plugin.go b/plugins/metrics/plugin.go index df6ea122..474bb21d 100644 --- a/plugins/metrics/plugin.go +++ b/plugins/metrics/plugin.go @@ -224,6 +224,5 @@ func (m *Plugin) RPC() interface{} { } // Available interface implementation -func (m *Plugin) Available() bool { - return true +func (m *Plugin) Available() { } diff --git a/plugins/redis/plugin.go b/plugins/redis/plugin.go index b69af9d6..2eab7043 100644 --- a/plugins/redis/plugin.go +++ b/plugins/redis/plugin.go @@ -78,6 +78,5 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true +func (s *Plugin) Available() { } diff --git a/plugins/reload/plugin.go b/plugins/reload/plugin.go index d2c22fe8..7e6bdfec 100644 --- a/plugins/reload/plugin.go +++ b/plugins/reload/plugin.go @@ -163,6 +163,5 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true +func (s *Plugin) Available() { } diff --git a/plugins/resetter/plugin.go b/plugins/resetter/plugin.go index a80c2c0f..4feb692a 100644 --- a/plugins/resetter/plugin.go +++ b/plugins/resetter/plugin.go @@ -75,8 +75,7 @@ func (p *Plugin) Name() string { } // Available interface implementation -func (p *Plugin) Available() bool { - return true +func (p *Plugin) Available() { } // RPC returns associated rpc service. diff --git a/plugins/rpc/plugin.go b/plugins/rpc/plugin.go index f88aa6de..cfe20321 100644 --- a/plugins/rpc/plugin.go +++ b/plugins/rpc/plugin.go @@ -123,8 +123,7 @@ func (s *Plugin) Name() string { } // Available interface implementation -func (s *Plugin) Available() bool { - return true +func (s *Plugin) Available() { } // Collects all plugins which implement Name + RPCer interfaces diff --git a/plugins/server/plugin.go b/plugins/server/plugin.go index 64793034..22b568d8 100644 --- a/plugins/server/plugin.go +++ b/plugins/server/plugin.go @@ -59,8 +59,7 @@ func (server *Plugin) Name() string { } // Available interface implementation -func (server *Plugin) Available() bool { - return true +func (server *Plugin) Available() { } // Serve (Start) server plugin (just a mock here to satisfy interface) diff --git a/plugins/service/plugin.go b/plugins/service/plugin.go index 522fe192..28b84443 100644 --- a/plugins/service/plugin.go +++ b/plugins/service/plugin.go @@ -106,6 +106,5 @@ func (service *Plugin) Name() string { } // Available interface implementation -func (service *Plugin) Available() bool { - return true +func (service *Plugin) Available() { } diff --git a/plugins/status/plugin.go b/plugins/status/plugin.go index 3553bb01..82a0fa6c 100644 --- a/plugins/status/plugin.go +++ b/plugins/status/plugin.go @@ -128,9 +128,7 @@ func (c *Plugin) Name() string { } // Available interface implementation -func (c *Plugin) Available() bool { - return true -} +func (c *Plugin) Available() {} // RPC returns associated rpc service. func (c *Plugin) RPC() interface{} { diff --git a/tests/plugins/informer/test_plugin.go b/tests/plugins/informer/test_plugin.go index db757110..43335999 100644 --- a/tests/plugins/informer/test_plugin.go +++ b/tests/plugins/informer/test_plugin.go @@ -49,9 +49,7 @@ func (p1 *Plugin1) Name() string { return "informer.plugin1" } -func (p1 *Plugin1) Available() bool { - return true -} +func (p1 *Plugin1) Available() {} func (p1 *Plugin1) Workers() []process.State { p, err := p1.server.NewWorkerPool(context.Background(), testPoolConfig, nil) -- cgit v1.2.3 From 556477ca9df3fa2e5939057861314eabe5ce30ca Mon Sep 17 00:00:00 2001 From: Valery Piashchynski Date: Fri, 30 Apr 2021 16:04:55 +0300 Subject: - Make development log colored - Remove old TODOs Signed-off-by: Valery Piashchynski --- pkg/events/pool_events.go | 1 - pkg/pool/static_pool.go | 1 - pkg/transport/pipe/pipe_factory.go | 4 ---- plugins/kv/drivers/boltdb/driver.go | 2 -- plugins/logger/config.go | 30 +++++++++++++++++++++++++----- plugins/reload/watcher.go | 3 +-- tools/worker_table.go | 1 - 7 files changed, 26 insertions(+), 16 deletions(-) diff --git a/pkg/events/pool_events.go b/pkg/events/pool_events.go index c569a5a8..e7b451e0 100644 --- a/pkg/events/pool_events.go +++ b/pkg/events/pool_events.go @@ -1,6 +1,5 @@ package events -// TODO event numbers const ( // EventWorkerConstruct thrown when new worker is spawned. EventWorkerConstruct P = iota + 10000 diff --git a/pkg/pool/static_pool.go b/pkg/pool/static_pool.go index 129c6f7d..06005d98 100755 --- a/pkg/pool/static_pool.go +++ b/pkg/pool/static_pool.go @@ -153,7 +153,6 @@ func (sp *StaticPool) Exec(p payload.Payload) (payload.Payload, error) { } // worker want's to be terminated - // TODO careful with toString(rsp.Context) if len(rsp.Body) == 0 && toString(rsp.Context) == StopRequest { sp.stopWorker(w) return sp.Exec(p) diff --git a/pkg/transport/pipe/pipe_factory.go b/pkg/transport/pipe/pipe_factory.go index 0709413f..19f4f92d 100755 --- a/pkg/transport/pipe/pipe_factory.go +++ b/pkg/transport/pipe/pipe_factory.go @@ -42,7 +42,6 @@ func (f *Factory) SpawnWorkerWithTimeout(ctx context.Context, cmd *exec.Cmd, lis return } - // TODO why out is in? in, err := cmd.StdoutPipe() if err != nil { c <- SpawnResult{ @@ -52,7 +51,6 @@ func (f *Factory) SpawnWorkerWithTimeout(ctx context.Context, cmd *exec.Cmd, lis return } - // TODO why in is out? out, err := cmd.StdinPipe() if err != nil { c <- SpawnResult{ @@ -119,13 +117,11 @@ func (f *Factory) SpawnWorker(cmd *exec.Cmd, listeners ...events.Listener) (*wor return nil, errors.E(op, err) } - // TODO why out is in? in, err := cmd.StdoutPipe() if err != nil { return nil, errors.E(op, err) } - // TODO why in is out? out, err := cmd.StdinPipe() if err != nil { return nil, errors.E(op, err) diff --git a/plugins/kv/drivers/boltdb/driver.go b/plugins/kv/drivers/boltdb/driver.go index b596d4c3..2e2df527 100644 --- a/plugins/kv/drivers/boltdb/driver.go +++ b/plugins/kv/drivers/boltdb/driver.go @@ -401,8 +401,6 @@ func (d *Driver) startGCLoop() { //nolint:gocognit }) if err != nil { d.log.Error("error during the gc phase of update", "error", err) - // todo this error is ignored, it means, that timer still be active - // to prevent this, we need to invoke t.Stop() return false } } diff --git a/plugins/logger/config.go b/plugins/logger/config.go index c435e8be..d2236cac 100644 --- a/plugins/logger/config.go +++ b/plugins/logger/config.go @@ -40,7 +40,7 @@ type Config struct { ErrorOutput []string `mapstructure:"errorOutput"` } -// ZapConfig converts config into Zap configuration. +// BuildLogger converts config into Zap configuration. func (cfg *Config) BuildLogger() (*zap.Logger, error) { var zCfg zap.Config switch strings.ToLower(cfg.Mode) { @@ -49,7 +49,29 @@ func (cfg *Config) BuildLogger() (*zap.Logger, error) { case "production": zCfg = zap.NewProductionConfig() case "development": - zCfg = zap.NewDevelopmentConfig() + zCfg = zap.Config{ + Level: zap.NewAtomicLevelAt(zap.DebugLevel), + Development: true, + Encoding: "console", + EncoderConfig: zapcore.EncoderConfig{ + // Keys can be anything except the empty string. + TimeKey: "T", + LevelKey: "L", + NameKey: "N", + CallerKey: "C", + FunctionKey: zapcore.OmitKey, + MessageKey: "M", + StacktraceKey: "S", + LineEnding: zapcore.DefaultLineEnding, + EncodeLevel: ColoredLevelEncoder, + EncodeTime: zapcore.ISO8601TimeEncoder, + EncodeDuration: zapcore.StringDurationEncoder, + EncodeCaller: zapcore.ShortCallerEncoder, + EncodeName: ColoredNameEncoder, + }, + OutputPaths: []string{"stderr"}, + ErrorOutputPaths: []string{"stderr"}, + } case "raw": zCfg = zap.Config{ Level: zap.NewAtomicLevelAt(zap.InfoLevel), @@ -98,12 +120,10 @@ func (cfg *Config) BuildLogger() (*zap.Logger, error) { zCfg.ErrorOutputPaths = cfg.ErrorOutput } - // todo: - return zCfg.Build() } -// Initialize default logger +// InitDefault Initialize default logger func (cfg *Config) InitDefault() { if cfg.Mode == "" { cfg.Mode = "development" diff --git a/plugins/reload/watcher.go b/plugins/reload/watcher.go index 1b3407e5..421668b3 100644 --- a/plugins/reload/watcher.go +++ b/plugins/reload/watcher.go @@ -216,9 +216,8 @@ func (w *Watcher) waitEvent(d time.Duration) error { case <-ticker.C: // this is not very effective way // because we have to wait on Lock - // better is to listen files in parallel, but, since that would be used in debug... TODO + // better is to listen files in parallel, but, since that would be used in debug... for serviceName := range w.watcherConfigs { - // TODO sync approach fileList, _ := w.retrieveFileList(serviceName, w.watcherConfigs[serviceName]) w.pollEvents(w.watcherConfigs[serviceName].ServiceName, fileList) } diff --git a/tools/worker_table.go b/tools/worker_table.go index 4dd70d8e..799f045f 100644 --- a/tools/worker_table.go +++ b/tools/worker_table.go @@ -83,7 +83,6 @@ func renderStatus(status string) string { } func renderJobs(number uint64) string { - // TODO overflow return humanize.Comma(int64(number)) } -- cgit v1.2.3