+ /**
+ * Builds a mock XappApi object.
+ *
+ * @param instanceKey
+ * RIC instance
+ * @return Object that returns instance-specific results
+ */
+ private XappApi xappApi(String instanceKey) {
+ logger.debug("Creating XappApi for instance {}", instanceKey);
+ // Create instance-specific objects
+ String[] appNames = { "AdmissionControl " + instanceKey, "UE Event Collector " + instanceKey };
+ if (RICInstanceMockConfiguration.INSTANCE_KEY_1.equals(instanceKey)) {
+ appNames = Arrays.copyOf(appNames, appNames.length + 1);
+ appNames[appNames.length - 1] = "ANR " + instanceKey;
+ }
+ final String configJson = " { \"config\" : \"example-" + instanceKey + "\"}";
+ final String descriptorJson = " { \"descriptor\" : \"example-" + instanceKey + "\"}";
+ final AllXappConfig allXappConfigs = new AllXappConfig();
+ final AllDeployableXapps deployableApps = new AllDeployableXapps();
+ final AllDeployedXapps deployedXapps = new AllDeployedXapps();
+ for (String n : appNames) {
+ ConfigMetadata metadata = new ConfigMetadata().configName("config-" + n).name(n).namespace("namespace");
+ XAppConfig config = new XAppConfig().config(configJson).descriptor(descriptorJson).metadata(metadata);
+ allXappConfigs.add(config);
+ deployableApps.add(n);
+ Xapp xapp = new Xapp().name(n).version("version").status(StatusEnum.UNKNOWN);
+ xapp.addInstancesItem(new XappInstance().name("abcd-1234").ip("127.0.0.1").port(200)
+ .status(XappInstance.StatusEnum.RUNNING));
+ deployedXapps.add(xapp);
+ }
+ final SubscriptionResponse subRes = new SubscriptionResponse().eventType(SubscriptionResponse.EventTypeEnum.ALL)
+ .id("subid").version(1);
+ // Mock the methods to return the instance-specific objects