X-Git-Url: https://gerrit.o-ran-sc.org/r/gitweb?a=blobdiff_plain;f=policy-agent%2Fsrc%2Ftest%2Fjava%2Forg%2Foransc%2Fpolicyagent%2FApplicationTest.java;h=d22a9da8e826957346a5fe3e026f275d1ff146f9;hb=2aa1689637366d03a1252afadf93be937c1ec644;hp=32d7fe64e64e921d0f819041d2535b327f022888;hpb=41cbc8cef42c7b1d4ee78c8789f14bffd7d829dd;p=nonrtric.git diff --git a/policy-agent/src/test/java/org/oransc/policyagent/ApplicationTest.java b/policy-agent/src/test/java/org/oransc/policyagent/ApplicationTest.java index 32d7fe64..d22a9da8 100644 --- a/policy-agent/src/test/java/org/oransc/policyagent/ApplicationTest.java +++ b/policy-agent/src/test/java/org/oransc/policyagent/ApplicationTest.java @@ -21,11 +21,27 @@ package org.oransc.policyagent; import static org.assertj.core.api.Assertions.assertThat; +import java.net.URL; +import java.util.HashMap; +import java.util.Map; + import org.junit.Test; import org.junit.runner.RunWith; +import org.oransc.policyagent.configuration.ApplicationConfig; +import org.oransc.policyagent.repository.ImmutablePolicyType; +import org.oransc.policyagent.repository.Policies; +import org.oransc.policyagent.repository.Policy; +import org.oransc.policyagent.repository.PolicyType; +import org.oransc.policyagent.repository.PolicyTypes; +import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.boot.test.context.SpringBootTest.WebEnvironment; +import org.springframework.boot.test.context.TestConfiguration; import org.springframework.boot.web.server.LocalServerPort; +import org.springframework.context.annotation.Bean; +import org.springframework.http.HttpEntity; +import org.springframework.http.HttpHeaders; +import org.springframework.http.MediaType; import org.springframework.test.context.junit4.SpringRunner; import org.springframework.web.client.RestTemplate; @@ -33,6 +49,40 @@ import org.springframework.web.client.RestTemplate; @SpringBootTest(webEnvironment = WebEnvironment.RANDOM_PORT) public class ApplicationTest { + @Autowired + private Policies policies; + + @Autowired + private PolicyTypes policyTypes; + + @Autowired + ApplicationConfig appConfig; + + static class MockApplicationConfig extends ApplicationConfig { + public void initialize() { + URL url = MockApplicationConfig.class.getClassLoader().getResource("test_application_configuration.json"); + loadConfigurationFromFile(url.getFile()); + } + } + + @TestConfiguration + static class Beans { + @Bean + Policies getPolicies() { + return new Policies(); + } + + @Bean + PolicyTypes getPolicyTypes() { + return new PolicyTypes(); + } + + @Bean + ApplicationConfig getApplicationConfig() { + return new MockApplicationConfig(); + } + } + @LocalServerPort private int port; @@ -46,4 +96,55 @@ public class ApplicationTest { assertThat(rsp).contains("type3"); } + @Test + public void getRics() throws Exception { + String cmd = "/rics"; + String rsp = this.restTemplate.getForObject("http://localhost:" + port + cmd, String.class); + System.out.println("*** rsp " + rsp); + assertThat(rsp).contains("kista_1"); + } + + @Test + public void getRic() throws Exception { + String cmd = "/ric?managedElementId=kista_1"; + String rsp = this.restTemplate.getForObject("http://localhost:" + port + cmd, String.class); + assertThat(rsp).isEqualTo("ric1"); + } + + // managedElmentId -> nodeName + + @Test + public void putPolicy() throws Exception { + // types.putType("type1", ImmutablePolicyType.builder().name("").jsonSchema("").build()); + + String url = "http://localhost:" + port + "/policy?type={type}&instance={instance}&ric={ric}&service={service}"; + + Map uriVariables = new HashMap(); + uriVariables.put("type", "type1"); + uriVariables.put("instance", "instance1"); + uriVariables.put("ric", "ric1"); + uriVariables.put("service", "service"); + HttpHeaders headers = new HttpHeaders(); + headers.setContentType(MediaType.APPLICATION_JSON); + String json = "{}"; + HttpEntity entity = new HttpEntity(json); + + addPolicyType(policyTypes, "type1"); + + this.restTemplate.put(url, entity, uriVariables); + Policy policy = this.policies.get("instance1"); + assertThat(policy).isNotNull(); + assertThat(policy.id()).isEqualTo("instance1"); + assertThat(policy.ownerServiceName()).isEqualTo("service"); + } + + private void addPolicyType(PolicyTypes policyTypes, String name) { + PolicyType type = ImmutablePolicyType.builder() // + .jsonSchema("") // + .name(name) // + .build(); + + policyTypes.putType(name, type); + } + }