Some class of constraints should not be used for link cost evaluation.

ONOS-6021

Current ConnectivityIntentCompiler simply picks first non-negative cost as Link cost value.

Some class of constraints are used to express Path viability or IntentCompiler's behavior.
Those constraints tend to returns fixed arbitrary non-negative link cost, which probably is not the best option to be used as Link cost during path computation.

This patch will:
- Introduce base class for constraints which should not influence Link cost.
- Introduce base class for constraints which should not influence Link cost or Path viability.
- Exclude above classes from link cost computation in ConnectivityIntentCompiler

MarkerConstraint
 base class for Constraints,
 which is not meant to influence Link cost or Path viability.

PathViablityConstraint
 base class for Constraints,
 which is not meant to influence Link cost.

Change-Id: Ice8b83a18cfe3bf5a68c25a853667bfaedb2b1a1
diff --git a/core/api/src/main/java/org/onosproject/net/intent/constraint/HashedPathSelectionConstraint.java b/core/api/src/main/java/org/onosproject/net/intent/constraint/HashedPathSelectionConstraint.java
index 3cb120c..2ce6252 100644
--- a/core/api/src/main/java/org/onosproject/net/intent/constraint/HashedPathSelectionConstraint.java
+++ b/core/api/src/main/java/org/onosproject/net/intent/constraint/HashedPathSelectionConstraint.java
@@ -15,42 +15,9 @@
  */
 package org.onosproject.net.intent.constraint;
 
-import org.onosproject.net.Link;
-import org.onosproject.net.Path;
-import org.onosproject.net.intent.Constraint;
-import org.onosproject.net.intent.ResourceContext;
-
 /**
  * A constraint for intent.hashCode() based path selection.
  */
-public class HashedPathSelectionConstraint implements Constraint {
+public final class HashedPathSelectionConstraint extends MarkerConstraint {
 
-    @Override
-    public double cost(Link link, ResourceContext context) {
-        return 1;
-    }
-
-    @Override
-    public boolean validate(Path path, ResourceContext context) {
-        return true;
-    }
-
-    @Override
-    public int hashCode() {
-        return 1;
-    }
-
-    @Override
-    public boolean equals(Object obj) {
-        if (this == obj) {
-            return true;
-        }
-
-        return (obj != null && getClass().equals(obj.getClass()));
-    }
-
-    @Override
-    public String toString() {
-        return "HashedPathSelectionConstraint";
-    }
 }