From 146d47f6c92fc7f64ca940ca4629bf8997195b58 Mon Sep 17 00:00:00 2001 From: "lpsolit%gmail.com" <> Date: Mon, 17 Jul 2006 05:53:08 +0000 Subject: Bug 238819: enter_bug.cgi should offer ASSIGNED as a possible initial state - Patch by Frédéric Buclin r=vladd a=justdave MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- enter_bug.cgi | 31 +++++++++++++++++-------------- post_bug.cgi | 19 +++++++++++++------ 2 files changed, 30 insertions(+), 20 deletions(-) diff --git a/enter_bug.cgi b/enter_bug.cgi index 1315ca927..512650a7e 100755 --- a/enter_bug.cgi +++ b/enter_bug.cgi @@ -438,24 +438,27 @@ if ( Bugzilla->params->{'usetargetmilestone'} ) { } } +# Construct the list of allowable statuses. +# +# * If the product requires votes to confirm: +# users with privs : NEW + ASSI + UNCO +# users with no privs: UNCO +# +# * If the product doesn't require votes to confirm: +# users with privs : NEW + ASSI +# users with no privs: NEW (as these users cannot reassign +# bugs to them, it doesn't make sense +# to let them mark bugs as ASSIGNED) -# List of status values for drop-down. my @status; - -# Construct the list of allowable values. There are three cases: -# -# case values -# product does not have confirmation NEW -# confirmation, user cannot confirm UNCONFIRMED -# confirmation, user can confirm NEW, UNCONFIRMED. - +if ($user->in_group('editbugs') || $user->in_group('canconfirm')) { + @status = ('NEW', 'ASSIGNED'); +} +elsif (!$product->votes_to_confirm) { + @status = ('NEW'); +} if ($product->votes_to_confirm) { - if (UserInGroup("editbugs") || UserInGroup("canconfirm")) { - push(@status, "NEW"); - } push(@status, 'UNCONFIRMED'); -} else { - push(@status, "NEW"); } $vars->{'bug_status'} = \@status; diff --git a/post_bug.cgi b/post_bug.cgi index 2fa6576f2..b3f668e3f 100755 --- a/post_bug.cgi +++ b/post_bug.cgi @@ -202,17 +202,24 @@ if (Bugzilla->params->{"useqacontact"}) { } } +# Check the bug status. +# This order is important, see below. +my @valid_statuses = ('UNCONFIRMED', 'NEW', 'ASSIGNED'); + my $bug_status = 'UNCONFIRMED'; -if ($product->votes_to_confirm) { +if ($user->in_group('editbugs') || $user->in_group('canconfirm')) { # Default to NEW if the user with privs hasn't selected another status. - if (UserInGroup('editbugs') || UserInGroup('canconfirm')) { - $bug_status = scalar($cgi->param('bug_status')) || 'NEW'; - } -} else { + $bug_status = scalar($cgi->param('bug_status')) || 'NEW'; +} +elsif (!$product->votes_to_confirm) { $bug_status = 'NEW'; } $cgi->param(-name => 'bug_status', -value => $bug_status); +# Reject 'UNCONFIRMED' as a valid status if the product +# doesn't require votes to confirm its bugs. +shift @valid_statuses if !$product->votes_to_confirm; + if (!defined $cgi->param('target_milestone')) { $cgi->param(-name => 'target_milestone', -value => $product->default_milestone); } @@ -226,7 +233,7 @@ check_field('rep_platform', scalar $cgi->param('rep_platform')); check_field('bug_severity', scalar $cgi->param('bug_severity')); check_field('priority', scalar $cgi->param('priority')); check_field('op_sys', scalar $cgi->param('op_sys')); -check_field('bug_status', scalar $cgi->param('bug_status'), ['UNCONFIRMED', 'NEW']); +check_field('bug_status', scalar $cgi->param('bug_status'), \@valid_statuses); check_field('version', scalar $cgi->param('version'), [map($_->name, @{$product->versions})]); check_field('target_milestone', scalar $cgi->param('target_milestone'), -- cgit v1.2.3-24-g4f1b