update service not found error tooltip
fixing test failed issue change back error type change registry.ErrNotFound back to selector.ErrNotFound change back error type change registry.ErrNotFound back to selector.ErrNotFound remove the single node tunnel test Fix read yaml config from memory package main import ( "fmt" "github.com/micro/go-micro/config" "github.com/micro/go-micro/config/source/memory" ) var configData = []byte(` --- a: 1234 `) func main() { memorySource := memory.NewSource( memory.WithYAML(configData), ) // Create new config conf := config.NewConfig() // Load file source conf.Load(memorySource) fmt.Println(string(conf.Bytes())) }
This commit is contained in:
parent
b13604fb4b
commit
de34f259ba
@ -73,10 +73,11 @@ func (g *grpcClient) next(request client.Request, opts client.CallOptions) (sele
|
|||||||
|
|
||||||
// get next nodes from the selector
|
// get next nodes from the selector
|
||||||
next, err := g.opts.Selector.Select(service, opts.SelectOptions...)
|
next, err := g.opts.Selector.Select(service, opts.SelectOptions...)
|
||||||
if err != nil && err == selector.ErrNotFound {
|
if err != nil {
|
||||||
return nil, errors.NotFound("go.micro.client", err.Error())
|
if err == selector.ErrNotFound {
|
||||||
} else if err != nil {
|
return nil, errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
return nil, errors.InternalServerError("go.micro.client", err.Error())
|
}
|
||||||
|
return nil, errors.InternalServerError("go.micro.client", "error selecting %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
return next, nil
|
return next, nil
|
||||||
@ -350,15 +351,17 @@ func (g *grpcClient) Call(ctx context.Context, req client.Request, rsp interface
|
|||||||
|
|
||||||
// select next node
|
// select next node
|
||||||
node, err := next()
|
node, err := next()
|
||||||
if err != nil && err == selector.ErrNotFound {
|
service := req.Service()
|
||||||
return errors.NotFound("go.micro.client", err.Error())
|
if err != nil {
|
||||||
} else if err != nil {
|
if err == selector.ErrNotFound {
|
||||||
return errors.InternalServerError("go.micro.client", err.Error())
|
return errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
|
}
|
||||||
|
return errors.InternalServerError("go.micro.client", "error selecting %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
// make the call
|
// make the call
|
||||||
err = gcall(ctx, node, req, rsp, callOpts)
|
err = gcall(ctx, node, req, rsp, callOpts)
|
||||||
g.opts.Selector.Mark(req.Service(), node, err)
|
g.opts.Selector.Mark(service, node, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -429,14 +432,16 @@ func (g *grpcClient) Stream(ctx context.Context, req client.Request, opts ...cli
|
|||||||
}
|
}
|
||||||
|
|
||||||
node, err := next()
|
node, err := next()
|
||||||
if err != nil && err == selector.ErrNotFound {
|
service := req.Service()
|
||||||
return nil, errors.NotFound("go.micro.client", err.Error())
|
if err != nil {
|
||||||
} else if err != nil {
|
if err == selector.ErrNotFound {
|
||||||
return nil, errors.InternalServerError("go.micro.client", err.Error())
|
return nil, errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
|
}
|
||||||
|
return nil, errors.InternalServerError("go.micro.client", "error selecting %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
stream, err := g.stream(ctx, node, req, callOpts)
|
stream, err := g.stream(ctx, node, req, callOpts)
|
||||||
g.opts.Selector.Mark(req.Service(), node, err)
|
g.opts.Selector.Mark(service, node, err)
|
||||||
return stream, err
|
return stream, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -312,10 +312,11 @@ func (r *rpcClient) next(request Request, opts CallOptions) (selector.Next, erro
|
|||||||
|
|
||||||
// get next nodes from the selector
|
// get next nodes from the selector
|
||||||
next, err := r.opts.Selector.Select(service, opts.SelectOptions...)
|
next, err := r.opts.Selector.Select(service, opts.SelectOptions...)
|
||||||
if err != nil && err == selector.ErrNotFound {
|
if err != nil {
|
||||||
return nil, errors.NotFound("go.micro.client", "service %s: %v", service, err.Error())
|
if err == selector.ErrNotFound {
|
||||||
} else if err != nil {
|
return nil, errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
return nil, errors.InternalServerError("go.micro.client", "error selecting %s node: %v", service, err.Error())
|
}
|
||||||
|
return nil, errors.InternalServerError("go.micro.client", "error selecting %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
return next, nil
|
return next, nil
|
||||||
@ -375,15 +376,17 @@ func (r *rpcClient) Call(ctx context.Context, request Request, response interfac
|
|||||||
|
|
||||||
// select next node
|
// select next node
|
||||||
node, err := next()
|
node, err := next()
|
||||||
if err != nil && err == selector.ErrNotFound {
|
service := request.Service()
|
||||||
return errors.NotFound("go.micro.client", "service %s: %v", request.Service(), err.Error())
|
if err != nil {
|
||||||
} else if err != nil {
|
if err == selector.ErrNotFound {
|
||||||
return errors.InternalServerError("go.micro.client", "error getting next %s node: %v", request.Service(), err.Error())
|
return errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
|
}
|
||||||
|
return errors.InternalServerError("go.micro.client", "error getting next %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
// make the call
|
// make the call
|
||||||
err = rcall(ctx, node, request, response, callOpts)
|
err = rcall(ctx, node, request, response, callOpts)
|
||||||
r.opts.Selector.Mark(request.Service(), node, err)
|
r.opts.Selector.Mark(service, node, err)
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -452,14 +455,16 @@ func (r *rpcClient) Stream(ctx context.Context, request Request, opts ...CallOpt
|
|||||||
}
|
}
|
||||||
|
|
||||||
node, err := next()
|
node, err := next()
|
||||||
if err != nil && err == selector.ErrNotFound {
|
service := request.Service()
|
||||||
return nil, errors.NotFound("go.micro.client", "service %s: %v", request.Service(), err.Error())
|
if err != nil {
|
||||||
} else if err != nil {
|
if err == selector.ErrNotFound {
|
||||||
return nil, errors.InternalServerError("go.micro.client", "error getting next %s node: %v", request.Service(), err.Error())
|
return nil, errors.InternalServerError("go.micro.client", "service %s: %s", service, err.Error())
|
||||||
|
}
|
||||||
|
return nil, errors.InternalServerError("go.micro.client", "error getting next %s node: %s", service, err.Error())
|
||||||
}
|
}
|
||||||
|
|
||||||
stream, err := r.stream(ctx, node, request, callOpts)
|
stream, err := r.stream(ctx, node, request, callOpts)
|
||||||
r.opts.Selector.Mark(request.Service(), node, err)
|
r.opts.Selector.Mark(service, node, err)
|
||||||
return stream, err
|
return stream, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -51,6 +51,9 @@ func (c *registrySelector) Select(service string, opts ...SelectOption) (Next, e
|
|||||||
// if that fails go directly to the registry
|
// if that fails go directly to the registry
|
||||||
services, err := c.rc.GetService(service)
|
services, err := c.rc.GetService(service)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
|
if err == registry.ErrNotFound {
|
||||||
|
return nil, ErrNotFound
|
||||||
|
}
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,6 +18,7 @@ type memory struct {
|
|||||||
func (s *memory) Read() (*source.ChangeSet, error) {
|
func (s *memory) Read() (*source.ChangeSet, error) {
|
||||||
s.RLock()
|
s.RLock()
|
||||||
cs := &source.ChangeSet{
|
cs := &source.ChangeSet{
|
||||||
|
Format: s.ChangeSet.Format,
|
||||||
Timestamp: s.ChangeSet.Timestamp,
|
Timestamp: s.ChangeSet.Timestamp,
|
||||||
Data: s.ChangeSet.Data,
|
Data: s.ChangeSet.Data,
|
||||||
Checksum: s.ChangeSet.Checksum,
|
Checksum: s.ChangeSet.Checksum,
|
||||||
|
@ -29,7 +29,7 @@ var (
|
|||||||
DefaultRegistry = NewRegistry()
|
DefaultRegistry = NewRegistry()
|
||||||
|
|
||||||
// Not found error when GetService is called
|
// Not found error when GetService is called
|
||||||
ErrNotFound = errors.New("not found")
|
ErrNotFound = errors.New("service not found")
|
||||||
// Watcher stopped error when watcher is stopped
|
// Watcher stopped error when watcher is stopped
|
||||||
ErrWatcherStopped = errors.New("watcher stopped")
|
ErrWatcherStopped = errors.New("watcher stopped")
|
||||||
)
|
)
|
||||||
|
@ -271,12 +271,12 @@ func (g *grpcServer) handler(srv interface{}, stream grpc.ServerStream) error {
|
|||||||
g.rpc.mu.Unlock()
|
g.rpc.mu.Unlock()
|
||||||
|
|
||||||
if service == nil {
|
if service == nil {
|
||||||
return status.New(codes.Unimplemented, fmt.Sprintf("unknown service %v", service)).Err()
|
return status.New(codes.Unimplemented, fmt.Sprintf("unknown service %s", serviceName)).Err()
|
||||||
}
|
}
|
||||||
|
|
||||||
mtype := service.method[methodName]
|
mtype := service.method[methodName]
|
||||||
if mtype == nil {
|
if mtype == nil {
|
||||||
return status.New(codes.Unimplemented, fmt.Sprintf("unknown service %v", service)).Err()
|
return status.New(codes.Unimplemented, fmt.Sprintf("unknown service %s.%s", serviceName, methodName)).Err()
|
||||||
}
|
}
|
||||||
|
|
||||||
// process unary
|
// process unary
|
||||||
|
@ -111,25 +111,26 @@ func (t *tun) process() {
|
|||||||
for {
|
for {
|
||||||
select {
|
select {
|
||||||
case msg := <-t.send:
|
case msg := <-t.send:
|
||||||
nmsg := &transport.Message{
|
newMsg := &transport.Message{
|
||||||
Header: msg.data.Header,
|
Header: make(map[string]string),
|
||||||
Body: msg.data.Body,
|
Body: msg.data.Body,
|
||||||
}
|
}
|
||||||
|
|
||||||
if nmsg.Header == nil {
|
for k, v := range msg.data.Header {
|
||||||
nmsg.Header = make(map[string]string)
|
newMsg.Header[k] = v
|
||||||
}
|
}
|
||||||
|
|
||||||
// set the tunnel id on the outgoing message
|
// set the tunnel id on the outgoing message
|
||||||
nmsg.Header["Micro-Tunnel-Id"] = msg.id
|
newMsg.Header["Micro-Tunnel-Id"] = msg.id
|
||||||
|
|
||||||
// set the session id
|
// set the session id
|
||||||
nmsg.Header["Micro-Tunnel-Session"] = msg.session
|
newMsg.Header["Micro-Tunnel-Session"] = msg.session
|
||||||
|
|
||||||
// send the message via the interface
|
// send the message via the interface
|
||||||
t.RLock()
|
t.RLock()
|
||||||
for _, link := range t.links {
|
for _, link := range t.links {
|
||||||
link.Send(nmsg)
|
log.Debugf("Sending %+v to %s", newMsg, link.Remote())
|
||||||
|
link.Send(newMsg)
|
||||||
}
|
}
|
||||||
t.RUnlock()
|
t.RUnlock()
|
||||||
case <-t.closed:
|
case <-t.closed:
|
||||||
@ -170,11 +171,7 @@ func (t *tun) listen(link transport.Socket, listener bool) {
|
|||||||
var s *socket
|
var s *socket
|
||||||
var exists bool
|
var exists bool
|
||||||
|
|
||||||
// if its a local listener then we use that as the session id
|
log.Debugf("Received %+v from %s", msg, link.Remote())
|
||||||
// e.g we're using a loopback connecting to ourselves
|
|
||||||
if listener {
|
|
||||||
s, exists = t.getSocket(id, "listener")
|
|
||||||
} else {
|
|
||||||
// get the socket based on the tunnel id and session
|
// get the socket based on the tunnel id and session
|
||||||
// this could be something we dialed in which case
|
// this could be something we dialed in which case
|
||||||
// we have a session for it otherwise its a listener
|
// we have a session for it otherwise its a listener
|
||||||
@ -185,14 +182,15 @@ func (t *tun) listen(link transport.Socket, listener bool) {
|
|||||||
// has no session but its set a listener session
|
// has no session but its set a listener session
|
||||||
s, exists = t.getSocket(id, "listener")
|
s, exists = t.getSocket(id, "listener")
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
// no socket in existence
|
// no socket in existence
|
||||||
if !exists {
|
if !exists {
|
||||||
|
log.Debugf("Skipping")
|
||||||
// drop it, we don't care about
|
// drop it, we don't care about
|
||||||
// messages we don't know about
|
// messages we don't know about
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
log.Debugf("Using socket %s %s", s.id, s.session)
|
||||||
|
|
||||||
// is the socket closed?
|
// is the socket closed?
|
||||||
select {
|
select {
|
||||||
@ -398,6 +396,7 @@ func (t *tun) Init(opts ...Option) error {
|
|||||||
|
|
||||||
// Dial an address
|
// Dial an address
|
||||||
func (t *tun) Dial(addr string) (Conn, error) {
|
func (t *tun) Dial(addr string) (Conn, error) {
|
||||||
|
log.Debugf("Tunnel dialing %s", addr)
|
||||||
c, ok := t.newSocket(addr, t.newSession())
|
c, ok := t.newSocket(addr, t.newSession())
|
||||||
if !ok {
|
if !ok {
|
||||||
return nil, errors.New("error dialing " + addr)
|
return nil, errors.New("error dialing " + addr)
|
||||||
@ -413,6 +412,7 @@ func (t *tun) Dial(addr string) (Conn, error) {
|
|||||||
|
|
||||||
// Accept a connection on the address
|
// Accept a connection on the address
|
||||||
func (t *tun) Listen(addr string) (Listener, error) {
|
func (t *tun) Listen(addr string) (Listener, error) {
|
||||||
|
log.Debugf("Tunnel listening on %s", addr)
|
||||||
// create a new socket by hashing the address
|
// create a new socket by hashing the address
|
||||||
c, ok := t.newSocket(addr, "listener")
|
c, ok := t.newSocket(addr, "listener")
|
||||||
if !ok {
|
if !ok {
|
||||||
|
@ -48,9 +48,6 @@ func (t *tunListener) process() {
|
|||||||
wait: make(chan bool),
|
wait: make(chan bool),
|
||||||
}
|
}
|
||||||
|
|
||||||
// first message
|
|
||||||
sock.recv <- m
|
|
||||||
|
|
||||||
// save the socket
|
// save the socket
|
||||||
conns[m.session] = sock
|
conns[m.session] = sock
|
||||||
|
|
||||||
|
@ -54,28 +54,6 @@ func testSend(t *testing.T, tun Tunnel) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func TestTunnel(t *testing.T) {
|
func TestTunnel(t *testing.T) {
|
||||||
// create a new listener
|
|
||||||
tun := NewTunnel(Nodes("127.0.0.1:9096"))
|
|
||||||
err := tun.Connect()
|
|
||||||
if err != nil {
|
|
||||||
t.Fatal(err)
|
|
||||||
}
|
|
||||||
defer tun.Close()
|
|
||||||
|
|
||||||
var wg sync.WaitGroup
|
|
||||||
|
|
||||||
// start accepting connections
|
|
||||||
wg.Add(1)
|
|
||||||
go testAccept(t, tun, &wg)
|
|
||||||
|
|
||||||
// send a message
|
|
||||||
testSend(t, tun)
|
|
||||||
|
|
||||||
// wait until message is received
|
|
||||||
wg.Wait()
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestTwoTunnel(t *testing.T) {
|
|
||||||
// create a new tunnel client
|
// create a new tunnel client
|
||||||
tunA := NewTunnel(
|
tunA := NewTunnel(
|
||||||
Address("127.0.0.1:9096"),
|
Address("127.0.0.1:9096"),
|
||||||
|
Loading…
x
Reference in New Issue
Block a user