diff --git a/cluster/router/condition/app_router_test.go b/cluster/router/condition/app_router_test.go index bd817af36c8c144295479fb07ada9411f4115bbc..e99307625baf34fa6b744f168ff4e6cb8e042502 100644 --- a/cluster/router/condition/app_router_test.go +++ b/cluster/router/condition/app_router_test.go @@ -113,7 +113,7 @@ conditions: assert.Nil(t, err) assert.NotNil(t, appRouter) - rule, err := Parse(testYML) + rule, err := getRule(testYML) assert.Nil(t, err) appRouter.generateConditions(rule) diff --git a/cluster/router/condition/file.go b/cluster/router/condition/file.go index efeec53efc840d93c4b6906adfd19820a57b36fd..b2c876690043d18a1a9e746fee13f06c77a0de03 100644 --- a/cluster/router/condition/file.go +++ b/cluster/router/condition/file.go @@ -44,7 +44,7 @@ type FileConditionRouter struct { // NewFileConditionRouter Create file condition router instance with content ( from config file) func NewFileConditionRouter(content []byte) (*FileConditionRouter, error) { fileRouter := &FileConditionRouter{} - rule, err := Parse(string(content)) + rule, err := getRule(string(content)) if err != nil { return nil, perrors.Errorf("yaml.Unmarshal() failed , error:%v", perrors.WithStack(err)) } diff --git a/cluster/router/condition/listenable_router.go b/cluster/router/condition/listenable_router.go index ba2fbb0eb2f482dfde215c1b078ecad60e66bc14..4ccc19e95521d03ae1f663ec276646cf30926533 100644 --- a/cluster/router/condition/listenable_router.go +++ b/cluster/router/condition/listenable_router.go @@ -102,7 +102,7 @@ func (l *listenableRouter) Process(event *config_center.ConfigChangeEvent) { return } - routerRule, err := Parse(content) + routerRule, err := getRule(content) if err != nil { logger.Errorf("Parse condition router rule fail,error:[%s] ", err) return diff --git a/cluster/router/condition/router.go b/cluster/router/condition/router.go index c5d46444bde921386d14a8be7eb0a89d855f8ece..1a673525521169d5c317068e5ef2fd153d5f0cd8 100644 --- a/cluster/router/condition/router.go +++ b/cluster/router/condition/router.go @@ -27,7 +27,7 @@ import ( ) import ( - matcher "github.com/apache/dubbo-go/cluster/router/match" + matcher "github.com/apache/dubbo-go/cluster/router/util" "github.com/apache/dubbo-go/common" "github.com/apache/dubbo-go/common/constant" "github.com/apache/dubbo-go/common/logger" diff --git a/cluster/router/condition/router_rule.go b/cluster/router/condition/router_rule.go index 1374cf9de2585f78a27e3de99f356c6900268927..fc42d780145a8a825a91b0e35976722336e481af 100644 --- a/cluster/router/condition/router_rule.go +++ b/cluster/router/condition/router_rule.go @@ -17,12 +17,9 @@ package condition -import ( - "gopkg.in/yaml.v2" -) - import ( "github.com/apache/dubbo-go/cluster/router" + "github.com/apache/dubbo-go/common/yaml" ) // RouterRule RouterRule config read from config file or config center @@ -44,9 +41,9 @@ type RouterRule struct { * => * 1.1.1.1 */ -func Parse(rawRule string) (*RouterRule, error) { +func getRule(rawRule string) (*RouterRule, error) { r := &RouterRule{} - err := yaml.Unmarshal([]byte(rawRule), r) + err := yaml.UnmarshalYML([]byte(rawRule), r) if err != nil { return r, err } diff --git a/cluster/router/condition/router_rule_test.go b/cluster/router/condition/router_rule_test.go index 5acc7283917a7aa662b60cd90daba89d312db0cd..6b9fd8e71cb5195f7f9feb3c92f3ff4b4330c6bb 100644 --- a/cluster/router/condition/router_rule_test.go +++ b/cluster/router/condition/router_rule_test.go @@ -24,7 +24,7 @@ import ( "github.com/stretchr/testify/assert" ) -func TestParse(t *testing.T) { +func TestGetRule(t *testing.T) { testyml := ` scope: application runtime: true @@ -36,7 +36,7 @@ conditions: ip=127.0.0.1 => 1.1.1.1` - rule, e := Parse(testyml) + rule, e := getRule(testyml) assert.Nil(t, e) assert.NotNil(t, rule) diff --git a/cluster/router/tag/file.go b/cluster/router/tag/file.go index c9fb88db7415d0d9f4d08529506743120620257b..8144c83203dbe98778dd6bb8dcdb9888be664b3b 100644 --- a/cluster/router/tag/file.go +++ b/cluster/router/tag/file.go @@ -45,7 +45,7 @@ type FileTagRouter struct { // NewFileTagRouter Create file tag router instance with content ( from config file) func NewFileTagRouter(content []byte) (*FileTagRouter, error) { fileRouter := &FileTagRouter{} - rule, err := Parse(string(content)) + rule, err := getRule(string(content)) if err != nil { return nil, perrors.Errorf("yaml.Unmarshal() failed , error:%v", perrors.WithStack(err)) } diff --git a/cluster/router/tag/router_rule.go b/cluster/router/tag/router_rule.go index 3e910a9a076bbb3fe6e7926cdf09920d02b247cd..926446dcb2f18fa2fd4639a9246a85f435d75d45 100644 --- a/cluster/router/tag/router_rule.go +++ b/cluster/router/tag/router_rule.go @@ -17,12 +17,9 @@ package tag -import ( - "gopkg.in/yaml.v2" -) - import ( "github.com/apache/dubbo-go/cluster/router" + "github.com/apache/dubbo-go/common/yaml" ) // RouterRule RouterRule config read from config file or config center @@ -30,9 +27,9 @@ type RouterRule struct { router.BaseRouterRule `yaml:",inline""` } -func Parse(rawRule string) (*RouterRule, error) { +func getRule(rawRule string) (*RouterRule, error) { r := &RouterRule{} - err := yaml.Unmarshal([]byte(rawRule), r) + err := yaml.UnmarshalYML([]byte(rawRule), r) if err != nil { return r, err } diff --git a/cluster/router/tag/router_rule_test.go b/cluster/router/tag/router_rule_test.go index b61c1cb9c163665c8dc50411a63632496686b3f8..2df65193f9d0cf607258f3080e22b42cd6e9b16a 100644 --- a/cluster/router/tag/router_rule_test.go +++ b/cluster/router/tag/router_rule_test.go @@ -25,13 +25,13 @@ import ( "github.com/stretchr/testify/assert" ) -func TestParse(t *testing.T) { +func TestGetRule(t *testing.T) { yml := ` scope: application runtime: true force: true ` - rule, e := Parse(yml) + rule, e := getRule(yml) assert.Nil(t, e) assert.NotNil(t, rule) assert.Equal(t, true, rule.Force) diff --git a/cluster/router/match/match_utils.go b/cluster/router/util/match.go similarity index 99% rename from cluster/router/match/match_utils.go rename to cluster/router/util/match.go index 28fe7151c5126c41fbadf9f4d54da2b9df74a7fe..8b82087a3e171f62d7bc96feee3b7204507e95c4 100644 --- a/cluster/router/match/match_utils.go +++ b/cluster/router/util/match.go @@ -15,7 +15,7 @@ * limitations under the License. */ -package match +package util import ( "strings" diff --git a/cluster/router/match/match_utils_test.go b/cluster/router/util/match_test.go similarity index 99% rename from cluster/router/match/match_utils_test.go rename to cluster/router/util/match_test.go index f16480f1d3b7dd5ca820c81d5d04d837c129687f..ae8dad65be1e1d21f0cf2194b62164820f2765c9 100644 --- a/cluster/router/match/match_utils_test.go +++ b/cluster/router/util/match_test.go @@ -15,7 +15,7 @@ * limitations under the License. */ -package match +package util import ( "testing" diff --git a/common/yaml/yaml.go b/common/yaml/yaml.go index 7c31d71c35fff547d2ed0a765e8245717148a451..93ebb166144510236aff27a67422a6377ccb5c9f 100644 --- a/common/yaml/yaml.go +++ b/common/yaml/yaml.go @@ -48,3 +48,7 @@ func UnmarshalYMLConfig(confProFile string, out interface{}) ([]byte, error) { } return confFileStream, yaml.Unmarshal(confFileStream, out) } + +func UnmarshalYML(data []byte, out interface{}) error { + return yaml.Unmarshal(data, out) +} diff --git a/common/yaml/yaml_test.go b/common/yaml/yaml_test.go index 45eee59048c1c074b9c386e26cc7a2252896e6ea..c8b8258a68951a1437ac2e617c13ee5af4b3a5ee 100644 --- a/common/yaml/yaml_test.go +++ b/common/yaml/yaml_test.go @@ -46,6 +46,18 @@ func TestUnmarshalYMLConfig_Error(t *testing.T) { assert.Error(t, err) } +func TestUnmarshalYML(t *testing.T) { + c := &Config{} + b, err := LoadYMLConfig("./testdata/config.yml") + assert.NoError(t, err) + err = UnmarshalYML(b, c) + assert.NoError(t, err) + assert.Equal(t, "strTest", c.StrTest) + assert.Equal(t, 11, c.IntTest) + assert.Equal(t, false, c.BooleanTest) + assert.Equal(t, "childStrTest", c.ChildConfig.StrTest) +} + type Config struct { StrTest string `yaml:"strTest" default:"default" json:"strTest,omitempty" property:"strTest"` IntTest int `default:"109" yaml:"intTest" json:"intTest,omitempty" property:"intTest"`