Skip to content
Snippets Groups Projects
Commit fb96a376 authored by 邹毅贤's avatar 邹毅贤
Browse files

fix review problems

parent f41f7bf2
No related branches found
No related tags found
No related merge requests found
......@@ -19,12 +19,12 @@ package config
import (
"context"
"github.com/apache/dubbo-go/common/constant"
"net/url"
"time"
)
import (
"github.com/apache/dubbo-go/common/constant"
"github.com/creasty/defaults"
)
......
......@@ -19,17 +19,24 @@ package apollo
import (
"fmt"
"github.com/go-errors/errors"
"regexp"
"strconv"
"strings"
"sync"
)
import (
"github.com/go-errors/errors"
)
import (
"github.com/apache/dubbo-go/common"
"github.com/apache/dubbo-go/common/constant"
. "github.com/apache/dubbo-go/config_center"
"github.com/apache/dubbo-go/config_center/parser"
"github.com/apache/dubbo-go/remoting"
)
import (
"github.com/zouyx/agollo"
)
......@@ -131,6 +138,8 @@ func (c *apolloConfiguration) getAddressWithProtocolPrefix(url *common.URL) stri
address := url.Location
converted := address
if len(address) != 0 {
reg := regexp.MustCompile("\\s+")
address = reg.ReplaceAllString(address, "")
parts := strings.Split(address, ",")
addrs := make([]string, 0)
for _, part := range parts {
......
......@@ -19,29 +19,102 @@ package apollo
import (
"context"
"fmt"
"net/http"
"net/http/httptest"
"strings"
"sync"
"testing"
)
import (
"github.com/apache/dubbo-go/common"
"github.com/apache/dubbo-go/config"
"github.com/apache/dubbo-go/config_center"
"github.com/apache/dubbo-go/config_center/parser"
"github.com/apache/dubbo-go/remoting"
)
import (
"github.com/stretchr/testify/assert"
"net/http"
"net/http/httptest"
"strings"
"sync"
"testing"
)
const (
mockAppId = "testApplication_yang"
mockCluster = "dev"
mockNamespace = "mockDubbog.properties"
mockNotifyRes = `[{"namespaceName":"mockDubbog","notificationId":53050,"messages":{"details":{"testApplication_yang+default+mockDubbog":53050}}}]`
mockServiceConfigRes = `[{"appName":"APOLLO-CONFIGSERVICE","instanceId":"instance-300408ep:apollo-configservice:8080","homepageUrl":"http://localhost:8080"}]`
mockAppId = "testApplication_yang"
mockCluster = "dev"
mockNamespace = "mockDubbog.properties"
mockNotifyRes = `[{
"namespaceName": "mockDubbog",
"notificationId": 53050,
"messages": {
"details": {
"testApplication_yang+default+mockDubbog": 53050
}
}
}]`
mockServiceConfigRes = `[{
"appName": "APOLLO-CONFIGSERVICE",
"instanceId": "instance-300408ep:apollo-configservice:8080",
"homepageUrl": "http://localhost:8080"
}]`
)
var (
mockConfigRes = `{"appId":"testApplication_yang","cluster":"default","namespaceName":"mockDubbog.properties","configurations":{"registries.hangzhouzk.username":"","application.owner":"ZX","registries.shanghaizk.username":"","protocols.dubbo.ip":"127.0.0.1","protocol_conf.dubbo.getty_session_param.tcp_write_timeout":"5s","services.UserProvider.cluster":"failover","application.module":"dubbogo user-info server","services.UserProvider.interface":"com.ikurento.user.UserProvider","protocol_conf.dubbo.getty_session_param.compress_encoding":"false","registries.shanghaizk.address":"127.0.0.1:2182","protocol_conf.dubbo.session_timeout":"20s","registries.shanghaizk.timeout":"3s","protocol_conf.dubbo.getty_session_param.keep_alive_period":"120s","services.UserProvider.warmup":"100","application.version":"0.0.1","registries.hangzhouzk.protocol":"zookeeper","registries.hangzhouzk.password":"","protocols.dubbo.name":"dubbo","protocol_conf.dubbo.getty_session_param.wait_timeout":"1s","protocols.dubbo.port":"20000","application_config.owner":"demo","application_config.name":"demo","application_config.version":"0.0.1","application_config.environment":"dev","protocol_conf.dubbo.getty_session_param.session_name":"server","application.name":"BDTService","registries.hangzhouzk.timeout":"3s","protocol_conf.dubbo.getty_session_param.tcp_read_timeout":"1s","services.UserProvider.loadbalance":"random","protocol_conf.dubbo.session_number":"700","protocol_conf.dubbo.getty_session_param.max_msg_len":"1024","services.UserProvider.registry":"hangzhouzk","application_config.module":"demo","services.UserProvider.methods[0].name":"GetUser","protocol_conf.dubbo.getty_session_param.tcp_no_delay":"true","services.UserProvider.methods[0].retries":"1","protocol_conf.dubbo.getty_session_param.tcp_w_buf_size":"65536","protocol_conf.dubbo.getty_session_param.tcp_r_buf_size":"262144","registries.shanghaizk.password":"","application_config.organization":"demo","registries.shanghaizk.protocol":"zookeeper","protocol_conf.dubbo.getty_session_param.tcp_keep_alive":"true","registries.hangzhouzk.address":"127.0.0.1:2181","application.environment":"dev","services.UserProvider.protocol":"dubbo","application.organization":"ikurento.com","protocol_conf.dubbo.getty_session_param.pkg_wq_size":"512","services.UserProvider.methods[0].loadbalance":"random"},"releaseKey":"20191104105242-0f13805d89f834a4"}`
mockConfigRes = `{
"appId": "testApplication_yang",
"cluster": "default",
"namespaceName": "mockDubbog.properties",
"configurations": {
"registries.hangzhouzk.username": "",
"application.owner": "ZX",
"registries.shanghaizk.username": "",
"protocols.dubbo.ip": "127.0.0.1",
"protocol_conf.dubbo.getty_session_param.tcp_write_timeout": "5s",
"services.UserProvider.cluster": "failover",
"application.module": "dubbogo user-info server",
"services.UserProvider.interface": "com.ikurento.user.UserProvider",
"protocol_conf.dubbo.getty_session_param.compress_encoding": "false",
"registries.shanghaizk.address": "127.0.0.1:2182",
"protocol_conf.dubbo.session_timeout": "20s",
"registries.shanghaizk.timeout": "3s",
"protocol_conf.dubbo.getty_session_param.keep_alive_period": "120s",
"services.UserProvider.warmup": "100",
"application.version": "0.0.1",
"registries.hangzhouzk.protocol": "zookeeper",
"registries.hangzhouzk.password": "",
"protocols.dubbo.name": "dubbo",
"protocol_conf.dubbo.getty_session_param.wait_timeout": "1s",
"protocols.dubbo.port": "20000",
"application_config.owner": "demo",
"application_config.name": "demo",
"application_config.version": "0.0.1",
"application_config.environment": "dev",
"protocol_conf.dubbo.getty_session_param.session_name": "server",
"application.name": "BDTService",
"registries.hangzhouzk.timeout": "3s",
"protocol_conf.dubbo.getty_session_param.tcp_read_timeout": "1s",
"services.UserProvider.loadbalance": "random",
"protocol_conf.dubbo.session_number": "700",
"protocol_conf.dubbo.getty_session_param.max_msg_len": "1024",
"services.UserProvider.registry": "hangzhouzk",
"application_config.module": "demo",
"services.UserProvider.methods[0].name": "GetUser",
"protocol_conf.dubbo.getty_session_param.tcp_no_delay": "true",
"services.UserProvider.methods[0].retries": "1",
"protocol_conf.dubbo.getty_session_param.tcp_w_buf_size": "65536",
"protocol_conf.dubbo.getty_session_param.tcp_r_buf_size": "262144",
"registries.shanghaizk.password": "",
"application_config.organization": "demo",
"registries.shanghaizk.protocol": "zookeeper",
"protocol_conf.dubbo.getty_session_param.tcp_keep_alive": "true",
"registries.hangzhouzk.address": "127.0.0.1:2181",
"application.environment": "dev",
"services.UserProvider.protocol": "dubbo",
"application.organization": "ikurento.com",
"protocol_conf.dubbo.getty_session_param.pkg_wq_size": "512",
"services.UserProvider.methods[0].loadbalance": "random"
},
"releaseKey": "20191104105242-0f13805d89f834a4"
}`
)
func initApollo() *httptest.Server {
......@@ -121,7 +194,15 @@ func TestAddListener(t *testing.T) {
listener := &apolloDataListener{}
listener.wg.Add(1)
apollo := initMockApollo(t)
mockConfigRes = `{"appId":"testApplication_yang","cluster":"default","namespaceName":"mockDubbog.properties","configurations":{"registries.hangzhouzk.username":"11111"},"releaseKey":"20191104105242-0f13805d89f834a4"}`
mockConfigRes = `{
"appId": "testApplication_yang",
"cluster": "default",
"namespaceName": "mockDubbog.properties",
"configurations": {
"registries.hangzhouzk.username": "11111"
},
"releaseKey": "20191104105242-0f13805d89f834a4"
}`
apollo.AddListener(mockNamespace, listener)
listener.wg.Wait()
assert.Equal(t, "registries.hangzhouzk.username", listener.event)
......@@ -131,7 +212,15 @@ func TestAddListener(t *testing.T) {
func TestRemoveListener(t *testing.T) {
listener := &apolloDataListener{}
apollo := initMockApollo(t)
mockConfigRes = `{"appId":"testApplication_yang","cluster":"default","namespaceName":"mockDubbog.properties","configurations":{"registries.hangzhouzk.username":"11111"},"releaseKey":"20191104105242-0f13805d89f834a4"}`
mockConfigRes = `{
"appId": "testApplication_yang",
"cluster": "default",
"namespaceName": "mockDubbog.properties",
"configurations": {
"registries.hangzhouzk.username": "11111"
},
"releaseKey": "20191104105242-0f13805d89f834a4"
}`
apollo.AddListener(mockNamespace, listener)
apollo.RemoveListener(mockNamespace, listener)
assert.Equal(t, "", listener.event)
......@@ -158,7 +247,6 @@ func (l *apolloDataListener) Process(configType *config_center.ConfigChangeEvent
if configType.ConfigType != remoting.EventTypeUpdate {
return
}
fmt.Println("process!!!!!")
l.wg.Done()
l.count++
l.event = configType.Key
......
......@@ -19,6 +19,9 @@ package apollo
import (
"github.com/apache/dubbo-go/config_center"
)
import (
"github.com/zouyx/agollo"
)
......
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment