bugfix - fixed the healthcheck problem 60/127460/1
authorGuangrongFu <fu.guangrong@zte.com.cn>
Thu, 3 Mar 2022 03:33:59 +0000 (11:33 +0800)
committerGuangrongFu <fu.guangrong@zte.com.cn>
Thu, 3 Mar 2022 03:33:59 +0000 (11:33 +0800)
Issue-ID: HOLMES-512
Signed-off-by: GuangrongFu <fu.guangrong@zte.com.cn>
Change-Id: I4393c649468157c00f3ea57568056b087b76554c

rulemgt/src/main/java/org/onap/holmes/rulemgt/Initializer.java
rulemgt/src/test/java/org/onap/holmes/rulemgt/InitializerTest.java

index 812ee48..3995e4c 100644 (file)
@@ -30,6 +30,7 @@ import javax.annotation.PostConstruct;
 import javax.inject.Inject;
 import java.util.HashSet;
 import java.util.Set;
 import javax.inject.Inject;
 import java.util.HashSet;
 import java.util.Set;
+import java.util.concurrent.Executors;
 import java.util.concurrent.TimeUnit;
 
 import static org.onap.holmes.common.utils.CommonUtils.getEnv;
 import java.util.concurrent.TimeUnit;
 
 import static org.onap.holmes.common.utils.CommonUtils.getEnv;
@@ -38,7 +39,7 @@ import static org.onap.holmes.common.utils.CommonUtils.isIpAddress;
 @Service
 public class Initializer {
     private static final Logger logger = LoggerFactory.getLogger(Initializer.class);
 @Service
 public class Initializer {
     private static final Logger logger = LoggerFactory.getLogger(Initializer.class);
-    private static boolean readyForMsbReg = false;
+    private volatile static boolean readyForMsbReg = false;
     private MsbRegister msbRegister;
 
     @Inject
     private MsbRegister msbRegister;
 
     @Inject
@@ -48,17 +49,19 @@ public class Initializer {
 
     @PostConstruct
     private void init() {
 
     @PostConstruct
     private void init() {
-        waitUntilReady();
-        try {
-            msbRegister.register2Msb(createMicroServiceInfo());
-        } catch (CorrelationException e) {
-            logger.error(e.getMessage(), e);
-        }
+        Executors.newSingleThreadExecutor().execute(() -> {
+            waitUntilReady();
+            try {
+                msbRegister.register2Msb(createMicroServiceInfo());
+            } catch (CorrelationException e) {
+                logger.error(e.getMessage(), e);
+            }
+        });
     }
 
     private void waitUntilReady() {
         int count = 1;
     }
 
     private void waitUntilReady() {
         int count = 1;
-        while(!readyForMsbReg) {
+        while (!readyForMsbReg) {
             if (count > 20) {
                 break;
             }
             if (count > 20) {
                 break;
             }
index f658d35..8e4a6fe 100644 (file)
@@ -51,6 +51,8 @@ public class InitializerTest {
 
         WhiteboxImpl.invokeMethod(initializer, "init");
 
 
         WhiteboxImpl.invokeMethod(initializer, "init");
 
+        TimeUnit.SECONDS.sleep(6);
+
         PowerMock.verifyAll();
     }
 
         PowerMock.verifyAll();
     }