From 35b63d77bd8887fcc74f28b2d21f1c8faabc9df5 Mon Sep 17 00:00:00 2001 From: Jim Hahn Date: Thu, 25 Apr 2019 18:39:48 -0400 Subject: Add copy constructor for PdpStatus Change-Id: Id818d3b16355ad3f3a96ff4456ec8e8062055f98 Issue-ID: POLICY-1645 Signed-off-by: Jim Hahn --- .../models/pdp/concepts/PdpResponseDetails.java | 13 +++++++++++++ .../policy/models/pdp/concepts/PdpStatistics.java | 17 +++++++++++++++++ .../onap/policy/models/pdp/concepts/PdpStatus.java | 21 +++++++++++++++++++++ 3 files changed, 51 insertions(+) (limited to 'models-pdp/src/main') diff --git a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpResponseDetails.java b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpResponseDetails.java index c28d01a3e..6b5bd6cea 100644 --- a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpResponseDetails.java +++ b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpResponseDetails.java @@ -22,6 +22,7 @@ package org.onap.policy.models.pdp.concepts; import lombok.Getter; +import lombok.NoArgsConstructor; import lombok.Setter; import lombok.ToString; import org.onap.policy.models.pdp.enums.PdpResponseStatus; @@ -34,10 +35,22 @@ import org.onap.policy.models.pdp.enums.PdpResponseStatus; @Getter @Setter @ToString +@NoArgsConstructor public class PdpResponseDetails { // The responseTo field should match the original request id in the request. private String responseTo; private PdpResponseStatus responseStatus; private String responseMessage; + + /** + * Constructs the object, making a deep copy. + * + * @param source source from which to copy + */ + public PdpResponseDetails(PdpResponseDetails source) { + this.responseMessage = source.responseMessage; + this.responseStatus = source.responseStatus; + this.responseTo = source.responseTo; + } } diff --git a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatistics.java b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatistics.java index 36e8d00f8..1847eed77 100644 --- a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatistics.java +++ b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatistics.java @@ -22,6 +22,7 @@ package org.onap.policy.models.pdp.concepts; import lombok.Getter; +import lombok.NoArgsConstructor; import lombok.Setter; import lombok.ToString; @@ -33,6 +34,7 @@ import lombok.ToString; @Getter @Setter @ToString +@NoArgsConstructor public class PdpStatistics { private String pdpInstanceId; @@ -42,4 +44,19 @@ public class PdpStatistics { private long policyExecutedCount; private long policyExecutedSuccessCount; private long policyExecutedFailCount; + + /** + * Constructs the object, making a deep copy. + * + * @param source source from which to copy + */ + public PdpStatistics(PdpStatistics source) { + this.pdpInstanceId = source.pdpInstanceId; + this.policyDeployCount = source.policyDeployCount; + this.policyDeployFailCount = source.policyDeployFailCount; + this.policyDeploySuccessCount = source.policyDeploySuccessCount; + this.policyExecutedCount = source.policyExecutedCount; + this.policyExecutedFailCount = source.policyExecutedFailCount; + this.policyExecutedSuccessCount = source.policyExecutedSuccessCount; + } } diff --git a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatus.java b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatus.java index 5858b6acd..3655aa796 100644 --- a/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatus.java +++ b/models-pdp/src/main/java/org/onap/policy/models/pdp/concepts/PdpStatus.java @@ -25,6 +25,7 @@ import java.util.List; import lombok.Getter; import lombok.Setter; import lombok.ToString; +import org.onap.policy.models.base.PfUtils; import org.onap.policy.models.pdp.enums.PdpHealthStatus; import org.onap.policy.models.pdp.enums.PdpMessageType; import org.onap.policy.models.pdp.enums.PdpState; @@ -64,4 +65,24 @@ public class PdpStatus extends PdpMessage { public PdpStatus() { super(PdpMessageType.PDP_STATUS); } + + /** + * Constructs the object, making a deep copy. + * + * @param source source from which to copy + */ + public PdpStatus(PdpStatus source) { + super(source); + + this.pdpType = source.pdpType; + this.state = source.state; + this.healthy = source.healthy; + this.description = source.description; + this.supportedPolicyTypes = PfUtils.mapList(source.supportedPolicyTypes, ToscaPolicyTypeIdentifier::new); + this.policies = PfUtils.mapList(source.policies, ToscaPolicyIdentifier::new); + this.deploymentInstanceInfo = source.deploymentInstanceInfo; + this.properties = source.properties; + this.statistics = (source.statistics == null ? null : new PdpStatistics(source.statistics)); + this.response = (source.response == null ? null : new PdpResponseDetails(source.response)); + } } -- cgit 1.2.3-korg