Merge pull request #577 from milosgajdos83/update-events

Added update action to handle update registry events. Table.Update inserts when no route found.
This commit is contained in:
Asim Aslam 2019-07-10 21:54:48 +01:00 committed by GitHub
commit 382fbecd40
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 27 additions and 20 deletions

View File

@ -83,6 +83,7 @@ func (r *router) Options() Options {
func (r *router) manageServiceRoutes(service *registry.Service, action string) error { func (r *router) manageServiceRoutes(service *registry.Service, action string) error {
// action is the routing table action // action is the routing table action
action = strings.ToLower(action) action = strings.ToLower(action)
// take route action on each service node // take route action on each service node
for _, node := range service.Nodes { for _, node := range service.Nodes {
route := table.Route{ route := table.Route{
@ -93,19 +94,25 @@ func (r *router) manageServiceRoutes(service *registry.Service, action string) e
Link: table.DefaultLink, Link: table.DefaultLink,
Metric: table.DefaultLocalMetric, Metric: table.DefaultLocalMetric,
} }
switch action { switch action {
case "insert", "create": case "create":
if err := r.opts.Table.Create(route); err != nil && err != table.ErrDuplicateRoute { if err := r.Create(route); err != nil && err != table.ErrDuplicateRoute {
return fmt.Errorf("failed adding route for service %s: %s", service.Name, err) return fmt.Errorf("failed adding route for service %s: %s", service.Name, err)
} }
case "update":
if err := r.Update(route); err != nil && err != table.ErrDuplicateRoute {
return fmt.Errorf("failed updating route for service %s: %s", service.Name, err)
}
case "delete": case "delete":
if err := r.opts.Table.Delete(route); err != nil && err != table.ErrRouteNotFound { if err := r.Delete(route); err != nil && err != table.ErrRouteNotFound {
return fmt.Errorf("failed deleting route for service %v: %s", service.Name, err) return fmt.Errorf("failed deleting route for service %s: %s", service.Name, err)
} }
default: default:
return fmt.Errorf("failed to manage route for service %v. Unknown action: %s", service.Name, action) return fmt.Errorf("failed to manage route for service %s. Unknown action: %s", service.Name, action)
} }
} }
return nil return nil
} }
@ -376,12 +383,12 @@ func (r *router) Advertise() (<-chan *Advert, error) {
if r.status.Code != Running { if r.status.Code != Running {
// add all local service routes into the routing table // add all local service routes into the routing table
if err := r.manageRegistryRoutes(r.opts.Registry, "insert"); err != nil { if err := r.manageRegistryRoutes(r.opts.Registry, "create"); err != nil {
return nil, fmt.Errorf("failed adding routes: %s", err) return nil, fmt.Errorf("failed adding routes: %s", err)
} }
// list routing table routes to announce // list routing table routes to announce
routes, err := r.opts.Table.List() routes, err := r.List()
if err != nil { if err != nil {
return nil, fmt.Errorf("failed listing routes: %s", err) return nil, fmt.Errorf("failed listing routes: %s", err)
} }
@ -406,7 +413,7 @@ func (r *router) Advertise() (<-chan *Advert, error) {
Network: "*", Network: "*",
Metric: table.DefaultLocalMetric, Metric: table.DefaultLocalMetric,
} }
if err := r.opts.Table.Create(route); err != nil { if err := r.Create(route); err != nil {
return nil, fmt.Errorf("failed adding default gateway route: %s", err) return nil, fmt.Errorf("failed adding default gateway route: %s", err)
} }
} }
@ -420,7 +427,7 @@ func (r *router) Advertise() (<-chan *Advert, error) {
} }
// routing table watcher // routing table watcher
tableWatcher, err := r.opts.Table.Watch() tableWatcher, err := r.Watch()
if err != nil { if err != nil {
return nil, fmt.Errorf("failed creating routing table watcher: %v", err) return nil, fmt.Errorf("failed creating routing table watcher: %v", err)
} }
@ -487,7 +494,7 @@ func (r *router) Process(a *Advert) error {
for _, event := range events { for _, event := range events {
// create a copy of the route // create a copy of the route
route := event.Route route := event.Route
if err := r.opts.Table.Update(route); err != nil { if err := r.Update(route); err != nil {
return fmt.Errorf("failed updating routing table: %v", err) return fmt.Errorf("failed updating routing table: %v", err)
} }
} }

View File

@ -106,17 +106,16 @@ func (t *table) Update(r Route) error {
// check if the route destination has any routes in the table // check if the route destination has any routes in the table
if _, ok := t.m[service]; !ok { if _, ok := t.m[service]; !ok {
return ErrRouteNotFound t.m[service] = make(map[uint64]Route)
}
// if the route has been found update it
if _, ok := t.m[service][sum]; ok {
t.m[service][sum] = r t.m[service][sum] = r
go t.sendEvent(&Event{Type: Update, Timestamp: time.Now(), Route: r}) go t.sendEvent(&Event{Type: Create, Timestamp: time.Now(), Route: r})
return nil return nil
} }
return ErrRouteNotFound t.m[service][sum] = r
go t.sendEvent(&Event{Type: Update, Timestamp: time.Now(), Route: r})
return nil
} }
// List returns a list of all routes in the table // List returns a list of all routes in the table

View File

@ -94,12 +94,13 @@ func TestUpdate(t *testing.T) {
t.Errorf("invalid number of routes. Expected: %d, found: %d", testTableSize, table.Size()) t.Errorf("invalid number of routes. Expected: %d, found: %d", testTableSize, table.Size())
} }
// this should error as the destination does not exist // this should add a new route
route.Service = "rand.dest" route.Service = "rand.dest"
if err := table.Update(route); err != ErrRouteNotFound { if err := table.Update(route); err != nil {
t.Errorf("error updating route. Expected error: %s, found: %s", ErrRouteNotFound, err) t.Errorf("error updating route: %s", err)
} }
testTableSize += 1
if table.Size() != testTableSize { if table.Size() != testTableSize {
t.Errorf("invalid number of routes. Expected: %d, found: %d", testTableSize, table.Size()) t.Errorf("invalid number of routes. Expected: %d, found: %d", testTableSize, table.Size())