Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Ftr: consul registry #121

Merged
merged 54 commits into from
Aug 26, 2019
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
54 commits
Select commit Hold shift + click to select a range
d04c33e
consul init
Jun 21, 2019
858f7c9
update
Jun 21, 2019
26959d1
solve conflict
Jul 1, 2019
dc0e93b
update consul
Jul 2, 2019
a231f0e
add consul example
Jul 2, 2019
5e0a4a1
Merge branch 'master' into consul
Jul 3, 2019
7564165
go mod
Jul 3, 2019
0adb3a9
go fmt
Jul 3, 2019
dcde19b
fix bug: add wg.done
Jul 3, 2019
127f034
Merge branch 'master' into consul
Jul 3, 2019
461cfc3
Merge branch 'develop' into consul
Jul 3, 2019
8970b13
modify travis
Jul 3, 2019
218cc74
new go.sum
Jul 3, 2019
c37e13a
modify go mod
Jul 3, 2019
65ae799
new go.mod and go.sum
Jul 4, 2019
eeb1177
update gitignore
Jul 4, 2019
f82563f
merge develop branch
Jul 9, 2019
87e9bab
modify based rw
Jul 9, 2019
340b98b
fix bug
Jul 9, 2019
85582d5
add for
Jul 9, 2019
cbb0534
improve consul examples
Jul 12, 2019
64df877
merge develop
Jul 17, 2019
97e0e51
add consul in travis
Jul 17, 2019
01485b5
modify travis
Jul 17, 2019
c8e0403
modify travis
Jul 17, 2019
f671f55
modify travis
Jul 17, 2019
bc10a18
modify travis
Jul 17, 2019
1ca3536
modfiy travis
Jul 17, 2019
4b29e7c
modify travis
Jul 17, 2019
e4a39c9
add unit test for consul
Jul 27, 2019
588dd96
resolve conflict
Jul 27, 2019
1bb5457
fix typo
Jul 31, 2019
82fb516
recolve conflict
Aug 11, 2019
a958f13
resolve conflict
Aug 11, 2019
f616b4a
fix initialize len and cap for make
Aug 11, 2019
803c1b2
resolve conflict
Aug 14, 2019
24e7d6f
Merge branch 'develop' into consul
Aug 14, 2019
1edd0f5
Merge branch 'develop' into consul
Aug 19, 2019
bd25bbd
fix typo
Aug 19, 2019
114b0c9
Merge branch 'develop' into consul
Aug 19, 2019
38a4b0c
consul test
Aug 19, 2019
2aa483a
consul test
Aug 19, 2019
46cc00a
travis
Aug 19, 2019
11032c5
import
Aug 19, 2019
5c05d1c
fix typo
Aug 19, 2019
c52c611
Merge branch 'develop' into consul
Aug 19, 2019
dd8728e
test
Aug 19, 2019
85c89b7
revert
Aug 19, 2019
e77abb3
go mod
Aug 20, 2019
d11fff0
typo
Aug 20, 2019
8125771
modify version
Aug 22, 2019
f73ee62
examples
Aug 22, 2019
21d7b15
add unregister test
Aug 23, 2019
5dd2bd0
modify yaml
Aug 23, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
add unit test for consul
  • Loading branch information
高辛格 committed Jul 27, 2019
commit e4a39c93e8becc102c492f266f92a19eb5acdbb9
4 changes: 4 additions & 0 deletions common/url.go
Original file line number Diff line number Diff line change
Expand Up @@ -108,16 +108,19 @@ func WithParams(params url.Values) option {
url.Params = params
}
}

func WithParamsValue(key, val string) option {
return func(url *URL) {
url.Params.Set(key, val)
}
}

func WithProtocol(proto string) option {
return func(url *URL) {
url.Protocol = proto
}
}

func WithIp(ip string) option {
return func(url *URL) {
url.Ip = ip
Expand All @@ -141,6 +144,7 @@ func WithLocation(location string) option {
url.Location = location
}
}

func NewURLWithOptions(opts ...option) *URL {
url := &URL{}
for _, opt := range opts {
Expand Down
12 changes: 5 additions & 7 deletions config/config_loader.go
Original file line number Diff line number Diff line change
Expand Up @@ -37,8 +37,8 @@ var (
maxWait = 3
)

// loaded comsumer & provider config from xxx.yml, and log config from xxx.xml
// Namely: dubbo.comsumer.xml & dubbo.provider.xml in java dubbo
// loaded consumer & provider config from xxx.yml, and log config from xxx.xml
// Namely: dubbo.consumer.xml & dubbo.provider.xml in java dubbo
func init() {
var (
confConFile, confProFile string
Expand Down Expand Up @@ -67,9 +67,8 @@ func Load() {
}
for key, ref := range consumerConfig.References {
rpcService := GetConsumerService(key)

if rpcService == nil {
logger.Warnf("%s is not exsist!", key)
logger.Warnf("%s does not exist!", key)
continue
}
ref.id = key
Expand All @@ -96,7 +95,7 @@ func Load() {
break
}
if refconfig.invoker == nil {
logger.Warnf("The interface %s invoker not exsist , may you should check your interface config.", refconfig.InterfaceName)
logger.Warnf("The interface %s invoker not exist , may you should check your interface config.", refconfig.InterfaceName)
}
}
}
Expand All @@ -116,9 +115,8 @@ func Load() {
}
for key, svs := range providerConfig.Services {
rpcService := GetProviderService(key)
fmt.Println(key)
if rpcService == nil {
logger.Warnf("%s is not exsist!", key)
logger.Warnf("%s does not exist!", key)
continue
}
svs.id = key
Expand Down
158 changes: 158 additions & 0 deletions registry/consul/consul_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,158 @@
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/

package consul

import (
"fmt"
"net"
"net/url"
"strconv"
"sync"
"testing"
)

import (
"github.com/hashicorp/consul/sdk/testutil"
"github.com/stretchr/testify/assert"
)

import (
"github.com/apache/dubbo-go/common"
"github.com/apache/dubbo-go/common/constant"
)

var (
registryHost = "localhost"
registryPort = 8500
providerHost = "localhost"
providerPort = 8000
consumerHost = "localhost"
consumerPort = 8001
service = "HelloWorld"
protocol = "tcp"
)

func newProviderRegistryUrl(host string, port int) *common.URL {
url1 := common.NewURLWithOptions(
common.WithIp(host),
common.WithPort(strconv.Itoa(port)),
common.WithParams(url.Values{}),
common.WithParamsValue(constant.ROLE_KEY, strconv.Itoa(common.PROVIDER)),
)
return url1
}

func newConsumerRegistryUrl(host string, port int) *common.URL {
url1 := common.NewURLWithOptions(
common.WithIp(host),
common.WithPort(strconv.Itoa(port)),
common.WithParams(url.Values{}),
common.WithParamsValue(constant.ROLE_KEY, strconv.Itoa(common.CONSUMER)),
)
return url1
}

func newProviderUrl(host string, port int, service string, protocol string) common.URL {
url1 := common.NewURLWithOptions(
common.WithIp(host),
common.WithPort(strconv.Itoa(port)),
common.WithPath(service),
common.WithProtocol(protocol),
)
return *url1
}

func newConsumerUrl(host string, port int, service string, protocol string) common.URL {
url1 := common.NewURLWithOptions(
common.WithIp(host),
common.WithPort(strconv.Itoa(port)),
common.WithPath(service),
common.WithProtocol(protocol),
)
return *url1
}

type Server struct {
listener net.Listener
wg sync.WaitGroup
done chan struct{}
}

func newServer(host string, port int) *Server {
addr := fmt.Sprintf("%s:%d", host, port)
tcpAddr, _ := net.ResolveTCPAddr("tcp", addr)
listener, _ := net.ListenTCP("tcp", tcpAddr)

server := &Server{
listener: listener,
done: make(chan struct{}, 1),
}

server.wg.Add(1)
go server.serve()
return server
}

func (server *Server) serve() {
defer server.wg.Done()
for {
select {
case <-server.done:
return
default:
conn, err := server.listener.Accept()
if err != nil {
continue
}
conn.Write([]byte("Hello World"))
conn.Close()
}
}
}

func (server *Server) close() {
close(server.done)
server.listener.Close()
server.wg.Wait()
}

func TestSomething(t *testing.T) {
providerRegistryUrl := newProviderRegistryUrl(registryHost, registryPort)
consumerRegistryUrl := newConsumerRegistryUrl(registryHost, registryPort)
providerUrl := newProviderUrl(providerHost, providerPort, service, protocol)
consumerUrl := newConsumerUrl(consumerHost, consumerPort, service, protocol)

cb := func(c *testutil.TestServerConfig) { c.Ports.HTTP = registryPort }
consulServer, _ := testutil.NewTestServerConfig(cb)
defer consulServer.Stop()
providerRegistry, err := newConsulRegistry(providerRegistryUrl)
assert.NoError(t, err)
consumerRegistry, err := newConsulRegistry(consumerRegistryUrl)
assert.NoError(t, err)

server := newServer(providerHost, providerPort)
defer server.close()
err = providerRegistry.Register(providerUrl)
assert.NoError(t, err)

listener, err := consumerRegistry.Subscribe(consumerUrl)
assert.NoError(t, err)
event, err := listener.Next()
assert.NoError(t, err)
assert.True(t, providerUrl.URLEqual(event.Service))
}