diff options
author | Parker Berberian <pberberian@iol.unh.edu> | 2019-01-03 19:23:05 +0000 |
---|---|---|
committer | Gerrit Code Review <gerrit@opnfv.org> | 2019-01-03 19:23:05 +0000 |
commit | 58248723155710045a7afa6b1717ae7f364e00cd (patch) | |
tree | d936b97318623607317117cb67ee763d7dd2ef80 | |
parent | 1f14bfbc9b2651c25498e6eb4418bdbd85329277 (diff) | |
parent | a0cbc41bc1691a7279a2a79401f00bf6b87796dd (diff) |
Merge "Requires a Jumphost per POD"
-rw-r--r-- | src/workflow/sw_bundle_workflow.py | 7 |
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'] = {} |