RIC-3057: Fix for retry in socket send 33/2533/1
authorwahidw <abdulwahid.w@nokia.com>
Tue, 18 Feb 2020 18:20:55 +0000 (18:20 +0000)
committerwahidw <abdulwahid.w@nokia.com>
Tue, 18 Feb 2020 18:21:02 +0000 (18:21 +0000)
Change-Id: I96ba72a59cb23af6148566b7b54d30d85e627138
Signed-off-by: wahidw <abdulwahid.w@nokia.com>
RELNOTES
container-tag.yaml
pkg/sbi/nngpush.go

index 8bcf0f8..b497112 100644 (file)
--- a/RELNOTES
+++ b/RELNOTES
@@ -1,3 +1,6 @@
+### v0.4.15
+* Retained (E2M->E2T issue) - retrying when is_Ready flag in socket handle is false 
+
 ### v0.4.14
 * Restart/Start of RM, fetch E2T data from E2manager - implementation in RM for v1/e2t/list API handling 
 
index 6b9814a..c754d3c 100644 (file)
@@ -2,4 +2,4 @@
 # By default this file is in the docker build directory,
 # but the location can configured in the JJB template.
 ---
-tag: 0.4.14
+tag: 0.4.15
index 1404319..b270abf 100644 (file)
@@ -50,14 +50,13 @@ import (
        _ "nanomsg.org/go/mangos/v2/transport/all"
        "routing-manager/pkg/rtmgr"
        "strconv"
+       "time"
 )
 
-
-
 type NngPush struct {
        Sbi
        NewSocket CreateNewNngSocketHandler
-        rcChan      chan *xapp.RMRParams
+       rcChan    chan *xapp.RMRParams
 }
 
 func NewNngPush() *NngPush {
@@ -150,10 +149,16 @@ func (c *NngPush) DistributeAll(policies *[]string) error {
        xapp.Logger.Debug("Invoked: sbi.DistributeAll")
        xapp.Logger.Debug("args: %v", *policies)
        for _, ep := range rtmgr.Eps {
-               if ep.IsReady {
-                       go c.send(ep, policies)
-               } else {
-                       xapp.Logger.Warn("Endpoint " + ep.Uuid + " is not ready")
+               i := 1
+               for i < 5 {
+                       if ep.IsReady {
+                               go c.send(ep, policies)
+                               break
+                       } else {
+                               xapp.Logger.Warn("Endpoint " + ep.Uuid + " is not ready" + " Retry count " + strconv.Itoa(i))
+                               time.Sleep(10 * time.Millisecond)
+                               i++
+                       }
                }
        }
        return nil