summaryrefslogtreecommitdiffstats
path: root/src/workflow
diff options
context:
space:
mode:
authorParker Berberian <pberberian@iol.unh.edu>2019-01-03 19:23:05 +0000
committerGerrit Code Review <gerrit@opnfv.org>2019-01-03 19:23:05 +0000
commit58248723155710045a7afa6b1717ae7f364e00cd (patch)
treed936b97318623607317117cb67ee763d7dd2ef80 /src/workflow
parent1f14bfbc9b2651c25498e6eb4418bdbd85329277 (diff)
parenta0cbc41bc1691a7279a2a79401f00bf6b87796dd (diff)
Merge "Requires a Jumphost per POD"
Diffstat (limited to 'src/workflow')
-rw-r--r--src/workflow/sw_bundle_workflow.py7
1 files changed, 7 insertions, 0 deletions
diff --git a/src/workflow/sw_bundle_workflow.py b/src/workflow/sw_bundle_workflow.py
index a9be4ea..80d1b3d 100644
--- a/src/workflow/sw_bundle_workflow.py
+++ b/src/workflow/sw_bundle_workflow.py
@@ -118,6 +118,7 @@ class Define_Software(WorkflowStep):
HostFormset = formset_factory(HostSoftwareDefinitionForm, extra=0)
formset = HostFormset(request.POST)
hosts = self.get_host_list()
+ has_jumphost = False
if formset.is_valid():
models['host_configs'] = []
i = 0
@@ -140,6 +141,8 @@ class Define_Software(WorkflowStep):
except:
self.metastep.set_invalid("Image " + image.name + " is not compatible with host " + host.resource.name)
role = form.cleaned_data['role']
+ if "jumphost" in role.name.lower():
+ has_jumphost = True
bundle = models['bundle']
hostConfig = HostConfiguration(
host=host,
@@ -151,6 +154,10 @@ class Define_Software(WorkflowStep):
confirm_host = {"name": host.resource.name, "image": image.name, "role": role.name}
confirm_hosts.append(confirm_host)
+ if not has_jumphost:
+ self.metastep.set_invalid('Must have at least one "Jumphost" per POD')
+ return self.render(request)
+
self.repo_put(self.repo.CONFIG_MODELS, models)
if "configuration" not in confirm:
confirm['configuration'] = {}