Get types at startup 83/1983/3
authorelinuxhenrik <henrik.b.andersson@est.tech>
Mon, 9 Dec 2019 16:06:04 +0000 (17:06 +0100)
committerelinuxhenrik <henrik.b.andersson@est.tech>
Tue, 10 Dec 2019 09:51:16 +0000 (10:51 +0100)
Change-Id: I94f8da731589bf45f1f0aa51a0663a5d2ecf7a56
Issue-ID: NONRTRIC-81
Signed-off-by: elinuxhenrik <henrik.b.andersson@est.tech>
policy-agent/src/main/java/org/oransc/policyagent/Application.java
policy-agent/src/main/java/org/oransc/policyagent/clients/RicClient.java [new file with mode: 0644]
policy-agent/src/main/java/org/oransc/policyagent/repository/PolicyTypes.java
policy-agent/src/main/java/org/oransc/policyagent/tasks/StartupService.java [moved from policy-agent/src/main/java/org/oransc/policyagent/controllers/StartupService.java with 67% similarity]
policy-agent/src/test/java/org/oransc/policyagent/tasks/StartupServiceTest.java [moved from policy-agent/src/test/java/org/oransc/policyagent/controllers/StartupServiceTest.java with 61% similarity]

index e4b6e5a..fdfca61 100644 (file)
@@ -20,7 +20,7 @@
 
 package org.oransc.policyagent;
 
-import org.oransc.policyagent.controllers.StartupService;
+import org.oransc.policyagent.tasks.StartupService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.boot.CommandLineRunner;
 import org.springframework.boot.SpringApplication;
@@ -39,7 +39,7 @@ public class Application {
     }
 
     /**
-     * Starts the se4rvice and reads the configuration.
+     * Starts the service and reads the configuration.
      *
      * @param ctx
      * @return
diff --git a/policy-agent/src/main/java/org/oransc/policyagent/clients/RicClient.java b/policy-agent/src/main/java/org/oransc/policyagent/clients/RicClient.java
new file mode 100644 (file)
index 0000000..709c023
--- /dev/null
@@ -0,0 +1,40 @@
+/*-
+ * ========================LICENSE_START=================================
+ * O-RAN-SC
+ * %%
+ * Copyright (C) 2019 Nordix Foundation
+ * %%
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ * ========================LICENSE_END===================================
+ */
+
+package org.oransc.policyagent.clients;
+
+import java.util.Vector;
+
+import org.oransc.policyagent.repository.PolicyType;
+import org.springframework.stereotype.Service;
+
+@Service
+public class RicClient {
+
+    public void deleteAllPolicies(String url) {
+        // TODO Auto-generated method stub
+
+    }
+
+    public Vector<PolicyType> getPolicyTypes(String url) {
+        return new Vector<>();
+    }
+
+}
index 6cf8ff4..f686ee4 100644 (file)
@@ -43,4 +43,11 @@ public class PolicyTypes {
         types.put(type.name(), type);
     }
 
+    public boolean contains(PolicyType policyType) {
+        return types.containsKey(policyType.name());
+    }
+
+    public int size() {
+        return types.size();
+    }
 }
  * ========================LICENSE_END===================================
  */
 
-package org.oransc.policyagent.controllers;
+package org.oransc.policyagent.tasks;
 
 import java.util.Vector;
 
+import org.oransc.policyagent.clients.RicClient;
 import org.oransc.policyagent.configuration.ApplicationConfig;
 import org.oransc.policyagent.configuration.RicConfig;
+import org.oransc.policyagent.repository.PolicyType;
+import org.oransc.policyagent.repository.PolicyTypes;
 import org.oransc.policyagent.repository.Ric;
+import org.oransc.policyagent.repository.Ric.RicState;
 import org.oransc.policyagent.repository.Rics;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
@@ -45,9 +49,17 @@ public class StartupService {
     @Autowired
     private Rics rics;
 
-    StartupService(ApplicationConfig appConfig, Rics rics) {
+    @Autowired
+    PolicyTypes policyTypes;
+
+    @Autowired
+    private RicClient ricClient;
+
+    StartupService(ApplicationConfig appConfig, Rics rics, PolicyTypes policyTypes, RicClient ricClient) {
         this.applicationConfig = appConfig;
         this.rics = rics;
+        this.policyTypes = policyTypes;
+        this.ricClient = ricClient;
     }
 
     /**
@@ -57,8 +69,16 @@ public class StartupService {
         applicationConfig.initialize();
         Vector<RicConfig> ricConfigs = applicationConfig.getRicConfigs();
         for (RicConfig ricConfig : ricConfigs) {
-            logger.error("Ric: {}", ricConfig);
             Ric ric = new Ric(ricConfig);
+            String baseUrl = ricConfig.baseUrl();
+            ricClient.deleteAllPolicies(baseUrl);
+            Vector<PolicyType> types = ricClient.getPolicyTypes(baseUrl);
+            for (PolicyType policyType : types) {
+                if (!policyTypes.contains(policyType)) {
+                    policyTypes.put(policyType);
+                }
+            }
+            ric.setState(RicState.ACTIVE);
             rics.put(ric);
         }
 
  * ========================LICENSE_END===================================
  */
 
-package org.oransc.policyagent.controllers;
+package org.oransc.policyagent.tasks;
 
 import static org.junit.Assert.assertEquals;
+import static org.mockito.ArgumentMatchers.anyString;
 import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.verify;
+import static org.mockito.Mockito.verifyNoMoreInteractions;
 import static org.mockito.Mockito.when;
 
 import java.util.Vector;
 
 import org.junit.Test;
+import org.oransc.policyagent.clients.RicClient;
 import org.oransc.policyagent.configuration.ApplicationConfig;
 import org.oransc.policyagent.configuration.ImmutableRicConfig;
 import org.oransc.policyagent.configuration.RicConfig;
+import org.oransc.policyagent.exceptions.ServiceException;
+import org.oransc.policyagent.repository.ImmutablePolicyType;
+import org.oransc.policyagent.repository.PolicyType;
+import org.oransc.policyagent.repository.PolicyTypes;
 import org.oransc.policyagent.repository.Rics;
 
 public class StartupServiceTest {
     ApplicationConfig appConfigMock;
 
     @Test
-    public void startup_allOk() {
+    public void startup_allOk() throws ServiceException {
         ApplicationConfig appConfigMock = mock(ApplicationConfig.class);
         Vector<RicConfig> ricConfigs = new Vector<>(2);
         Vector<String> firstNodes = new Vector<String>(1);
@@ -45,12 +53,26 @@ public class StartupServiceTest {
         when(appConfigMock.getRicConfigs()).thenReturn(ricConfigs);
 
         Rics rics = new Rics();
+        PolicyTypes policyTypes = new PolicyTypes();
 
-        StartupService serviceUnderTest = new StartupService(appConfigMock, rics);
+        Vector<PolicyType> types = new Vector<>();
+        PolicyType type = ImmutablePolicyType.builder().name("type1").jsonSchema("{}").build();
+        types.add(type);
+        RicClient ricClientMock = mock(RicClient.class);
+        when(ricClientMock.getPolicyTypes(anyString())).thenReturn(types);
+
+        StartupService serviceUnderTest = new StartupService(appConfigMock, rics, policyTypes, ricClientMock);
 
         serviceUnderTest.startup();
 
+        verify(ricClientMock).deleteAllPolicies("url");
+        verify(ricClientMock).getPolicyTypes("url");
+        verifyNoMoreInteractions(ricClientMock);
+
         assertEquals("Correct nymber of Rics not added to Rics", 1, rics.size());
         assertEquals("Not correct Ric added to Rics", "first", rics.getRic("first").name());
+
+        assertEquals("Not correct number of policy types added.", 1, policyTypes.size());
+        assertEquals("Not correct type added.", type, policyTypes.getType(type.name()));
     }
 }