From 58cb6fbea5bfeabfc02b24925c3ffc725f8d73dc Mon Sep 17 00:00:00 2001 From: Eelco Dolstra Date: Thu, 27 Nov 2008 21:40:23 +0000 Subject: [PATCH] --- src/Hydra/lib/Hydra/Controller/Root.pm | 22 +++++++++++++++++++++- src/Hydra/root/edit-releaseset.tt | 24 ++++++++++++++++++++++++ 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/src/Hydra/lib/Hydra/Controller/Root.pm b/src/Hydra/lib/Hydra/Controller/Root.pm index 9a114fda..8d35fb8f 100644 --- a/src/Hydra/lib/Hydra/Controller/Root.pm +++ b/src/Hydra/lib/Hydra/Controller/Root.pm @@ -213,7 +213,7 @@ sub getReleaseSet { $c->stash->{releaseSet} = $releaseSet; (my $primaryJob) = $releaseSet->releasesetjobs->search({isprimary => 1}); - die "Release set $releaseSetName doesn't have a primary job." if !defined $primaryJob; + #die "Release set $releaseSetName doesn't have a primary job." if !defined $primaryJob; $c->stash->{jobs} = [$releaseSet->releasesetjobs->search({}, {order_by => ["isprimary DESC", "job", "attrs"]})]; @@ -275,6 +275,26 @@ sub updateReleaseSet { $releaseSet->name($releaseSetName); $releaseSet->description(trim $c->request->params->{description}); $releaseSet->update; + + $releaseSet->releasesetjobs->delete_all; + + foreach my $param (keys %{$c->request->params}) { + next unless $param =~ /^job-(\d+)-name$/; + my $baseName = $1; + + my $name = trim $c->request->params->{"job-$baseName-name"}; + my $description = trim $c->request->params->{"job-$baseName-description"}; + my $attrs = trim $c->request->params->{"job-$baseName-attrs"}; + + $releaseSet->releasesetjobs->create( + { job => $name + , description => $description + , attrs => $attrs + , isprimary => $c->request->params->{"primary"} eq $baseName + }); + } + + die "There must be one primary job." if $releaseSet->releasesetjobs->search({isprimary => 1})->count != 1; } diff --git a/src/Hydra/root/edit-releaseset.tt b/src/Hydra/root/edit-releaseset.tt index 18fd8fcb..2b835935 100644 --- a/src/Hydra/root/edit-releaseset.tt +++ b/src/Hydra/root/edit-releaseset.tt @@ -17,6 +17,30 @@ + + + + + + + + + + + [% n = 0 %] + [% FOREACH job IN jobs %] + + + + + + + [% n = n + 1 %] + [% END %] + +
Primary jobJob nameDescriptionConstraint
"$n") %] /> [% n %] "job-$n-name", value => job.job) %] /> "job-$n-description", value => job.description) %] /> "job-$n-attrs", value => job.attrs) %] />
+