From: lpsolit%gmail.com <> Date: Sat, 7 Jul 2007 15:58:27 +0000 (+0000) Subject: Bug 376427: Exported XML files contain the incorrect status and resolution (they... X-Git-Tag: bugzilla-3.1.2~161 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=86a9c38e75690e12e39a3363093be6af78fbe087;p=thirdparty%2Fbugzilla.git Bug 376427: Exported XML files contain the incorrect status and resolution (they are always set to RESOLVED MOVED) - Patch by Frédéric Buclin r=mkanat a=LpSolit --- diff --git a/process_bug.cgi b/process_bug.cgi index d8620d138e..5cdb14e66c 100755 --- a/process_bug.cgi +++ b/process_bug.cgi @@ -59,6 +59,8 @@ use Bugzilla::Component; use Bugzilla::Keyword; use Bugzilla::Flag; +use Storable qw(dclone); + my $user = Bugzilla->login(LOGIN_REQUIRED); local our $whoid = $user->id; my $grouplist = $user->groups_as_string; @@ -474,18 +476,19 @@ if ($action eq Bugzilla->params->{'move-button-text'}) { 'cc READ', 'fielddefs READ', 'bug_status READ', 'status_workflow READ', 'resolution READ'); - my @bugs; # First update all moved bugs. - foreach my $id (@idlist) { - my $bug = new Bugzilla::Bug($id); - push(@bugs, $bug); - $bug->add_comment(scalar $cgi->param('comment'), + foreach my $bug (@bug_objects) { + $bug->add_comment(scalar $cgi->param('comment'), { type => CMT_MOVED_TO, extra_data => $user->login }); + } + # Don't export the new status and resolution. We want the current ones. + local $Storable::forgive_me = 1; + my $bugs = dclone(\@bug_objects); + foreach my $bug (@bug_objects) { $bug->set_status('RESOLVED'); $bug->set_resolution('MOVED'); } - - $_->update() foreach @bugs; + $_->update() foreach @bug_objects; $dbh->bz_unlock_tables(); # Now send emails. @@ -511,7 +514,7 @@ if ($action eq Bugzilla->params->{'move-button-text'}) { $displayfields{$_} = 1; } - $template->process("bug/show.xml.tmpl", { bugs => \@bugs, + $template->process("bug/show.xml.tmpl", { bugs => $bugs, displayfields => \%displayfields, }, \$msg) || ThrowTemplateError($template->error());