From ac46d23f05fa6eb45ca2d63ccfe28e24f79255c1 Mon Sep 17 00:00:00 2001 From: Daniel Baur Date: Mon, 13 Jan 2020 10:36:04 +0100 Subject: [PATCH 1/4] added sim type --- .../matchmaking/converters/NodeCandidateConverter.java | 9 ++++++--- .../org/cloudiator/matchmaking/domain/NodeCandidate.java | 8 +++++++- 2 files changed, 13 insertions(+), 4 deletions(-) diff --git a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/NodeCandidateConverter.java b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/NodeCandidateConverter.java index 554a51a..863c60f 100644 --- a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/NodeCandidateConverter.java +++ b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/NodeCandidateConverter.java @@ -4,11 +4,10 @@ import cloudiator.NodeType; import cloudiator.Runtime; import de.uniulm.omi.cloudiator.util.OneWayConverter; +import javax.annotation.Nullable; import org.cloudiator.matchmaking.domain.NodeCandidate; import org.cloudiator.messages.entities.MatchmakingEntities; -import javax.annotation.Nullable; - public class NodeCandidateConverter implements OneWayConverter { @@ -27,6 +26,7 @@ private NodeCandidateConverter() { public MatchmakingEntities.NodeCandidate apply(@Nullable NodeCandidate nodeCandidate) { switch (nodeCandidate.getType()) { case IAAS: + case SIMULATION: return applyIaas(nodeCandidate); case FAAS: return applyFaas(nodeCandidate); @@ -34,7 +34,8 @@ public MatchmakingEntities.NodeCandidate apply(@Nullable NodeCandidate nodeCandi return applyByon(nodeCandidate); case PAAS: default: - throw new IllegalStateException("Unsupported node candidate type: " + nodeCandidate.getType()); + throw new IllegalStateException( + "Unsupported node candidate type: " + nodeCandidate.getType()); } } @@ -84,6 +85,8 @@ private MatchmakingEntities.NodeCandidateType convertType(NodeType type) { return MatchmakingEntities.NodeCandidateType.NC_PAAS; case BYON: return MatchmakingEntities.NodeCandidateType.NC_BYON; + case SIMULATION: + return MatchmakingEntities.NodeCandidateType.NC_SIMULATION; default: throw new IllegalStateException(); diff --git a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java index 9de354a..7d4cd81 100644 --- a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java +++ b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java @@ -1,6 +1,7 @@ package org.cloudiator.matchmaking.domain; import cloudiator.Cloud; +import cloudiator.CloudType; import cloudiator.CloudiatorFactory; import cloudiator.Environment; import cloudiator.Hardware; @@ -32,7 +33,12 @@ public class NodeCandidate implements Comparable { public NodeCandidate(Cloud cloud, Hardware hardware, Image image, Location location, @Nullable Double price) { - this.type = NodeType.IAAS; + + if (cloud.getType().equals(CloudType.SIMULATION)) { + this.type = NodeType.SIMULATION; + } else { + this.type = NodeType.IAAS; + } this.cloud = cloud; this.hardware = hardware; this.image = image; From e6192c5f80ad3149aaa3cf1d51ac40c9aa6297ca Mon Sep 17 00:00:00 2001 From: Daniel Baur Date: Mon, 13 Jan 2020 11:09:20 +0100 Subject: [PATCH 2/4] added sim type --- .../matchmaking/converters/CloudConverter.java | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/CloudConverter.java b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/CloudConverter.java index 65decde..b3f2090 100644 --- a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/CloudConverter.java +++ b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/converters/CloudConverter.java @@ -32,7 +32,7 @@ public class CloudConverter implements TwoWayConverter Date: Mon, 13 Jan 2020 11:25:56 +0100 Subject: [PATCH 3/4] added sim type --- .../matchmaking/domain/HashingNodeCandidateIdGenerator.java | 1 + 1 file changed, 1 insertion(+) diff --git a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/HashingNodeCandidateIdGenerator.java b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/HashingNodeCandidateIdGenerator.java index e7d4844..f0cf0bc 100644 --- a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/HashingNodeCandidateIdGenerator.java +++ b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/HashingNodeCandidateIdGenerator.java @@ -32,6 +32,7 @@ public class HashingNodeCandidateIdGenerator implements NodeCandidateIdGenerator public String generateId(NodeCandidate nodeCandidate) { switch (nodeCandidate.getType()) { case IAAS: + case SIMULATION: return HASH_FUNCTION.hashObject(nodeCandidate, IAAS_NODE_CANDIDATE_FUNNEL).toString(); case FAAS: return HASH_FUNCTION.hashObject(nodeCandidate, FAAS_NODE_CANDIDATE_FUNNEL).toString(); From 3c42ff2386f5d04e2fe0379fcf709d463fe3f93d Mon Sep 17 00:00:00 2001 From: Daniel Baur Date: Mon, 13 Jan 2020 12:32:14 +0100 Subject: [PATCH 4/4] fixed toString --- .../matchmaking/domain/NodeCandidate.java | 14 ++++++++++++-- 1 file changed, 12 insertions(+), 2 deletions(-) diff --git a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java index 7d4cd81..ebbaa49 100644 --- a/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java +++ b/matchmaking-agent/src/main/java/org/cloudiator/matchmaking/domain/NodeCandidate.java @@ -199,8 +199,18 @@ public boolean equals(Object obj) { @Override public String toString() { - return MoreObjects.toStringHelper(this).add("hardware", hardware).add("image", image) - .add("location", location).add("price", price).toString(); + return MoreObjects.toStringHelper(this) + .add("id", id) + .add("type", type) + .add("cloud", cloud) + .add("location", location) + .add("hardware", hardware) + .add("image", image) + .add("price", price) + .add("pricePerInvocation", pricePerInvocation) + .add("memoryPrice", memoryPrice) + .add("environment", environment) + .toString(); } @Override