summaryrefslogtreecommitdiffstats
path: root/contrib
diff options
context:
space:
mode:
authorDavid Lawrence <dkl@mozilla.com>2014-08-12 08:17:25 +0200
committerByron Jones <glob@mozilla.com>2014-08-12 08:17:25 +0200
commitd4eb36bd5b8b7ebd0c1fdd08b6dc4c17129b98c3 (patch)
tree5fe9c5f6019263fd8e2ea953550c2cad80d5a51e /contrib
parentbc450dc015ffc325b10d9ffdf59a9b00f82cf70f (diff)
downloadbugzilla-d4eb36bd5b8b7ebd0c1fdd08b6dc4c17129b98c3.tar.gz
bugzilla-d4eb36bd5b8b7ebd0c1fdd08b6dc4c17129b98c3.tar.xz
Bug 1048053: convert bug 651803 dupes to INVALID bugs in "Invalid Bugs" product
Diffstat (limited to 'contrib')
-rwxr-xr-xcontrib/reorg-tools/move_dupes_to_invalid.pl99
1 files changed, 99 insertions, 0 deletions
diff --git a/contrib/reorg-tools/move_dupes_to_invalid.pl b/contrib/reorg-tools/move_dupes_to_invalid.pl
new file mode 100755
index 000000000..bf3590ff3
--- /dev/null
+++ b/contrib/reorg-tools/move_dupes_to_invalid.pl
@@ -0,0 +1,99 @@
+#!/usr/bin/perl
+# This Source Code Form is subject to the terms of the Mozilla Public
+# License, v. 2.0. If a copy of the MPL was not distributed with this
+# file, You can obtain one at http://mozilla.org/MPL/2.0/.
+#
+# This Source Code Form is "Incompatible With Secondary Licenses", as
+# defined by the Mozilla Public License, v. 2.0.
+
+use strict;
+use warnings;
+
+use FindBin '$RealBin';
+use lib "$RealBin/../..", "$RealBin/../../lib";
+
+use Bugzilla;
+use Bugzilla::User;
+use Bugzilla::Constants;
+use Bugzilla::Util qw(detaint_natural);
+use Bugzilla::Install::Util qw(indicate_progress);
+
+use Pod::Usage;
+
+BEGIN { Bugzilla->extensions(); }
+
+Bugzilla->usage_mode(USAGE_MODE_CMDLINE);
+
+pod2usage(1) unless @ARGV;
+
+my $dbh = Bugzilla->dbh;
+
+# Allow nobody@mozilla.org to edit bugs
+my $user = Bugzilla::User->check({ name => 'nobody@mozilla.org' });
+Bugzilla->set_user($user);
+$user->{'groups'} = [ Bugzilla::Group->new({ name => 'editbugs' }) ];
+
+my $timestamp = $dbh->selectrow_array('SELECT LOCALTIMESTAMP(0)');
+
+foreach my $dupe_of_bug (@ARGV) {
+ detaint_natural($dupe_of_bug) || pod2usage(1);
+ my $duped_bugs = $dbh->selectcol_arrayref("
+ SELECT DISTINCT dupe FROM duplicates WHERE dupe_of = ?",
+ undef, $dupe_of_bug);
+ my $bug_count = @$duped_bugs;
+
+ die "There are no duplicate bugs to move for bug $dupe_of_bug.\n"
+ if $bug_count == 0;
+
+ print STDERR <<EOF;
+Moving $bug_count duplicate bugs from bug $dupe_of_bug to the 'Invalid Bugs' product.
+
+Press <Ctrl-C> to stop or <Enter> to continue...
+EOF
+ getc();
+
+ $dbh->bz_start_transaction;
+ my $count = 0;
+ foreach my $duped_bug_id (@$duped_bugs) {
+ # Change product to "Invalid Bugs" and component to "General"
+ # Change resolution to "INVALID" instead of duplicate
+ # Change version to "unspecified" and milestone to "---"
+ # Reset assignee to default
+ # Reset QA contact to default
+ my $bug_obj = Bugzilla::Bug->new($duped_bug_id);
+ my $params = {
+ product => 'Invalid Bugs',
+ component => 'General',
+ resolution => 'INVALID',
+ version => 'unspecified',
+ target_milestone => '---',
+ reset_assigned_to => 1,
+ reset_qa_contact => 1
+ };
+ $params->{bug_status} = 'RESOLVED' if $bug_obj->status->is_open;
+ $bug_obj->set_all($params);
+ $bug_obj->update($timestamp);
+
+ $dbh->do("UPDATE bugs SET delta_ts = ?, lastdiffed = ? WHERE bug_id = ?",
+ undef, $timestamp, $timestamp, $duped_bug_id);
+
+ $count++;
+ indicate_progress({ current => $count, total => $bug_count, every => 1 });
+ }
+
+ Bugzilla::Hook::process('reorg_move_bugs', { bug_ids => [ $dupe_of_bug, @$duped_bugs ] });
+
+ $dbh->bz_commit_transaction();
+}
+
+Bugzilla->memcached->clear_all();
+
+__END__
+
+=head1 NAME
+
+move_dupes_to_invalid.pl - Script used to move dupes of a given bug to the 'Invalid Bugs' product.
+
+=head1 SYNOPSIS
+
+ move_dupes_to_invalid.pl <bug_id> [<bug_id> ...]