diff options
Diffstat (limited to 'components')
5 files changed, 48 insertions, 8 deletions
diff --git a/components/slice-analysis-ms/pom.xml b/components/slice-analysis-ms/pom.xml index 1eac47fe..b1e3eee8 100644 --- a/components/slice-analysis-ms/pom.xml +++ b/components/slice-analysis-ms/pom.xml @@ -32,7 +32,7 @@ <groupId>org.onap.dcaegen2.services.components</groupId> <artifactId>slice-analysis-ms</artifactId> - <version>1.0.1-SNAPSHOT</version> + <version>1.0.2-SNAPSHOT</version> <name>dcaegen2-services-slice-analysis-ms</name> <description>Network slice PM analyser</description> <packaging>jar</packaging> diff --git a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/models/Configuration.java b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/models/Configuration.java index 8bdbb1a8..91a07d4f 100644 --- a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/models/Configuration.java +++ b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/models/Configuration.java @@ -260,9 +260,18 @@ public class Configuration { minPercentageChange = jsonObject.get("sliceanalysisms.minPercentageChange").getAsInt(); initialDelaySeconds = jsonObject.get("sliceanalysisms.initialDelaySeconds").getAsLong(); - aafUsername = jsonObject.get("aafUsername").getAsString(); - aafPassword = jsonObject.get("aafPassword").getAsString(); - + if(jsonObject.get("aafUsername") == null) { + aafUsername = null; + } + else { + aafUsername = jsonObject.get("aafUsername").getAsString(); + } + if(jsonObject.get("aafPassword") == null) { + aafPassword = null; + } + else { + aafPassword = jsonObject.get("aafPassword").getAsString(); + } log.info("configuration from CBS {}", this); } } diff --git a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/ConsumerThread.java b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/ConsumerThread.java index 6868bc46..b676273f 100644 --- a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/ConsumerThread.java +++ b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/ConsumerThread.java @@ -25,6 +25,7 @@ import java.util.List; import org.onap.slice.analysis.ms.configdb.IConfigDbService; import org.onap.slice.analysis.ms.models.Configuration; +import org.onap.slice.analysis.ms.models.SubCounter; import org.onap.slice.analysis.ms.utils.BeanUtil; import org.slf4j.Logger; import org.slf4j.LoggerFactory; @@ -38,6 +39,7 @@ public class ConsumerThread extends Thread { private IConfigDbService configDbService; private SnssaiSamplesProcessor snssaiSamplesProcessor; private long initialDelaySec; + private int samples; /** * Default constructor. @@ -46,8 +48,8 @@ public class ConsumerThread extends Thread { super(); this.pmDataQueue = BeanUtil.getBean(PmDataQueue.class); this.configDbService = BeanUtil.getBean(IConfigDbService.class); - this.snssaiSamplesProcessor = BeanUtil.getBean(SnssaiSamplesProcessor.class); this.initialDelaySec = Configuration.getInstance().getInitialDelaySeconds(); + this.samples = Configuration.getInstance().getSamples(); } /** @@ -56,12 +58,13 @@ public class ConsumerThread extends Thread { @Override public void run() { boolean done = false; - String snssai = ""; boolean result = false; + String snssai = ""; List<String> nfs = null; while (!done) { try { Thread.sleep(initialDelaySec); + log.info("Starting Consumer Thread"); snssai = pmDataQueue.getSnnsaiFromQueue(); if (!snssai.equals("")) { log.info("Consumer thread processing data for s-nssai {}",snssai); @@ -72,7 +75,8 @@ public class ConsumerThread extends Thread { pmDataQueue.putSnssaiToQueue(snssai); log.error("Exception caught while fetching nfs of snssai {}, {}", snssai, e.getMessage()); } - if(nfs != null) { + if(nfs != null && checkForEnoughSamples(nfs, snssai)) { + this.snssaiSamplesProcessor = BeanUtil.getBean(SnssaiSamplesProcessor.class); result = snssaiSamplesProcessor.processSamplesOfSnnsai(snssai, nfs); if(!result) { log.info("Not enough samples to process for {}",snssai); @@ -86,4 +90,18 @@ public class ConsumerThread extends Thread { } } } + + /** + * Checks whether enough samples are available for the network functions + */ + public boolean checkForEnoughSamples(List<String> nfs, String snssai) { + for(String nf : nfs) { + if(! pmDataQueue.checkSamplesInQueue(new SubCounter(nf, snssai), samples)) { + log.info("Not enough samples to process for network function {} of snssai {}", nf, snssai); + pmDataQueue.putSnssaiToQueue(snssai); + return false; + } + } + return true; + } } diff --git a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/PmDataQueue.java b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/PmDataQueue.java index 4f196979..868b94c7 100644 --- a/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/PmDataQueue.java +++ b/components/slice-analysis-ms/src/main/java/org/onap/slice/analysis/ms/service/PmDataQueue.java @@ -79,6 +79,19 @@ public class PmDataQueue { } return sampleList; } + + /** + * check whether the queue has enough number of samples for that subcounter + */ + public boolean checkSamplesInQueue(SubCounter subCounter, int samples) { + if (subCounterMap.containsKey(subCounter)){ + Queue<List<MeasurementObject>> measQueue = subCounterMap.get(subCounter); + if(measQueue.size() >= samples) { + return true; + } + } + return false; + } /** * put S-NSSAI to the queue diff --git a/components/slice-analysis-ms/version.properties b/components/slice-analysis-ms/version.properties index 7bbc2fb0..34780e89 100644 --- a/components/slice-analysis-ms/version.properties +++ b/components/slice-analysis-ms/version.properties @@ -20,7 +20,7 @@ ############################################################################### major=1 minor=0 -patch=0 +patch=2 base_version=${major}.${minor}.${patch} release_version=${base_version} snapshot_version=${base_version}-SNAPSHOT |