Handling of A1 STD 1.1
[nonrtric.git] / policy-agent / src / test / java / org / oransc / policyagent / utils / MockA1ClientFactory.java
index 314c44c..52682fa 100644 (file)
 
 package org.oransc.policyagent.utils;
 
+import static org.mockito.Mockito.mock;
+import static org.mockito.Mockito.spy;
+
 import java.lang.invoke.MethodHandles;
 import java.util.HashMap;
 import java.util.Map;
 
 import org.oransc.policyagent.clients.A1Client;
 import org.oransc.policyagent.clients.A1ClientFactory;
+import org.oransc.policyagent.configuration.ApplicationConfig;
 import org.oransc.policyagent.repository.PolicyTypes;
 import org.oransc.policyagent.repository.Ric;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
+import reactor.core.publisher.Mono;
 
 public class MockA1ClientFactory extends A1ClientFactory {
     private static final Logger logger = LoggerFactory.getLogger(MethodHandles.lookup().lookupClass());
@@ -37,18 +42,19 @@ public class MockA1ClientFactory extends A1ClientFactory {
     private final PolicyTypes policyTypes;
 
     public MockA1ClientFactory(PolicyTypes policyTypes) {
+        super(mock(ApplicationConfig.class));
         this.policyTypes = policyTypes;
     }
 
     @Override
-    protected A1Client createStdA1ClientImpl(Ric ric) {
-        return getOrCreateA1Client(ric.name());
+    public Mono<A1Client> createA1Client(Ric ric) {
+        return Mono.just(getOrCreateA1Client(ric.name()));
     }
 
     public MockA1Client getOrCreateA1Client(String ricName) {
         if (!clients.containsKey(ricName)) {
             logger.debug("Creating client for RIC: {}", ricName);
-            MockA1Client client = new MockA1Client(policyTypes);
+            MockA1Client client = spy(new MockA1Client(policyTypes));
             clients.put(ricName, client);
         }
         return clients.get(ricName);