Add configurable delay to mock endpoints
[portal/ric-dashboard.git] / webapp-backend / src / main / java / org / oransc / ric / portal / dashboard / config / AnrXappMockConfiguration.java
index aaf522e..65960b9 100644 (file)
@@ -51,15 +51,19 @@ public class AnrXappMockConfiguration {
 
        private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
 
-       private final NeighborCellRelationTable ncrt, ncrtNodeB1, ncrtNodeB2, ncrtNodeB3;
-       private final GgNodeBTable gNodebTable;
-
        private static final String GNODEB1 = "001EF5:0045FE50";
        private static final String GNODEB2 = "001EF6:0045FE51";
        private static final String GNODEB3 = "001EF7:0045FE52";
+       // Sonar wants separate declarations
+       private final NeighborCellRelationTable ncrt;
+       private final NeighborCellRelationTable ncrtNodeB1;
+       private final NeighborCellRelationTable ncrtNodeB2;
+       private final NeighborCellRelationTable ncrtNodeB3;
+       private final GgNodeBTable gNodebTable;
+       // Simulate remote method delay for UI testing
+       private final int delayMs = 500;
 
        public AnrXappMockConfiguration() {
-
                logger.info("Configuring mock ANR xApp client");
                gNodebTable = new GgNodeBTable();
                gNodebTable.addGNodeBIdsItem(GNODEB1).addGNodeBIdsItem(GNODEB2).addGNodeBIdsItem(GNODEB3);
@@ -102,12 +106,8 @@ public class AnrXappMockConfiguration {
                ApiClient apiClient = apiClient();
                HealthApi mockApi = mock(HealthApi.class);
                when(mockApi.getApiClient()).thenReturn(apiClient);
-               doAnswer(i -> {
-                       return null;
-               }).when(mockApi).getHealthAlive();
-               doAnswer(i -> {
-                       return null;
-               }).when(mockApi).getHealthReady();
+               doAnswer(i -> null).when(mockApi).getHealthAlive();
+               doAnswer(i -> null).when(mockApi).getHealthReady();
                return mockApi;
        }
 
@@ -117,17 +117,45 @@ public class AnrXappMockConfiguration {
                ApiClient apiClient = apiClient();
                NcrtApi mockApi = mock(NcrtApi.class);
                when(mockApi.getApiClient()).thenReturn(apiClient);
-               when(mockApi.getgNodeB()).thenReturn(gNodebTable);
+               doAnswer(inv -> {
+                       logger.debug("getgNodeB sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return gNodebTable;
+               }).when(mockApi).getgNodeB();
                // Swagger sends nulls; front end sends empty strings
-               when(mockApi.getNcrt((String) isNull(), (String) isNull(), (String) isNull())).thenReturn(ncrt);
-               when(mockApi.getNcrt(eq(""), any(String.class), any(String.class))).thenReturn(ncrt);
-               when(mockApi.getNcrt(eq(GNODEB1), any(String.class), any(String.class))).thenReturn(ncrtNodeB1);
-               when(mockApi.getNcrt(eq(GNODEB2), any(String.class), any(String.class))).thenReturn(ncrtNodeB2);
-               when(mockApi.getNcrt(eq(GNODEB3), any(String.class), any(String.class))).thenReturn(ncrtNodeB3);
-               doAnswer(i -> {
+               doAnswer(inv -> {
+                       logger.debug("getNcrt (1) sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return ncrt;
+               }).when(mockApi).getNcrt((String) isNull(), (String) isNull(), (String) isNull());
+               doAnswer(inv -> {
+                       logger.debug("getNcrt (2) sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return ncrt;
+               }).when(mockApi).getNcrt(eq(""), any(String.class), any(String.class));
+               doAnswer(inv -> {
+                       logger.debug("getNcrt (3) sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return ncrtNodeB1;
+               }).when(mockApi).getNcrt(eq(GNODEB1), any(String.class), any(String.class));
+               doAnswer(inv -> {
+                       logger.debug("getNcrt (4) sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return ncrtNodeB2;
+               }).when(mockApi).getNcrt(eq(GNODEB2), any(String.class), any(String.class));
+               doAnswer(inv -> {
+                       logger.debug("getNcrt (5) sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
+                       return ncrtNodeB3;
+               }).when(mockApi).getNcrt(eq(GNODEB3), any(String.class), any(String.class));
+               doAnswer(inv -> {
+                       logger.debug("deleteNcrt sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
                        return null;
                }).when(mockApi).deleteNcrt(any(String.class), any(String.class));
-               doAnswer(i -> {
+               doAnswer(inv -> {
+                       logger.debug("modifyNcrt sleeping {}", delayMs);
+                       Thread.sleep(delayMs);
                        return null;
                }).when(mockApi).modifyNcrt(any(String.class), any(String.class), any(NeighborCellRelationMod.class));
                return mockApi;