Skip to content

Commit

Permalink
Bug 1301951 - Fix Bugzilla::Bug memory leaks
Browse files Browse the repository at this point in the history
  • Loading branch information
dylanwh committed Feb 26, 2017
1 parent 84ebf67 commit d3a58e0
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 5 deletions.
1 change: 1 addition & 0 deletions Bugzilla.pm
Original file line number Diff line number Diff line change
Expand Up @@ -686,6 +686,7 @@ sub _cleanup {
my $smtp = $cache->{smtp};
$smtp->disconnect if $smtp;
clear_request_cache();
Bugzilla::Bug->CLEANUP();

# These are both set by CGI.pm but need to be undone so that
# Apache can actually shut down its children if it needs to.
Expand Down
9 changes: 8 additions & 1 deletion Bugzilla/Attachment.pm
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@ use Bugzilla::Hook;

use File::Copy;
use List::Util qw(max);
use Scalar::Util qw(weaken isweak);
use Storable qw(dclone);

use parent qw(Bugzilla::Object);
Expand Down Expand Up @@ -140,8 +141,14 @@ the bug object to which the attachment is attached
=cut

sub bug {
my ($self) = @_;
require Bugzilla::Bug;
return $_[0]->{bug} //= Bugzilla::Bug->new({ id => $_[0]->bug_id, cache => 1 });
return $self->{bug} if defined $self->{bug};

# note $bug exists as a strong reference to keep $self->{bug} defined until the end of this method
my $bug = $self->{bug} = Bugzilla::Bug->new({ id => $_[0]->bug_id, cache => 1 });
weaken($self->{bug}) unless isweak($self->{bug});
return $bug;
}

=over
Expand Down
21 changes: 20 additions & 1 deletion Bugzilla/Bug.pm
Original file line number Diff line number Diff line change
Expand Up @@ -34,7 +34,7 @@ use Bugzilla::BugUserLastVisit;
use List::MoreUtils qw(firstidx uniq part);
use List::Util qw(min max first);
use Storable qw(dclone);
use Scalar::Util qw(blessed);
use Scalar::Util qw(blessed weaken);

use parent qw(Bugzilla::Object Exporter);
@Bugzilla::Bug::EXPORT = qw(
Expand All @@ -43,6 +43,9 @@ use parent qw(Bugzilla::Object Exporter);
editable_bug_fields
);

# This hash keeps a weak copy of every bug created.
my %CLEANUP;

#####################################################################
# Constants
#####################################################################
Expand Down Expand Up @@ -361,6 +364,9 @@ sub new {
return $error_self;
}

$CLEANUP{$self->id} = $self;
weaken($CLEANUP{$self->id});

return $self;
}

Expand All @@ -375,6 +381,18 @@ sub object_cache_key {
return $key . ',' . Bugzilla->user->id;
}

# This is called by Bugzilla::_cleanup() at the end of requests in a persistent environment
# (such as mod_perl)
sub CLEANUP {
foreach my $bug (values %CLEANUP) {
# $bug will be undef if there are no other references to it.
next unless $bug;
delete $bug->{depends_on_obj};
delete $bug->{blocks_obj};
}
%CLEANUP = ();
}

sub check {
my $class = shift;
my ($param, $field) = @_;
Expand Down Expand Up @@ -3696,6 +3714,7 @@ sub comments {
foreach my $comment (@{ $self->{'comments'} }) {
$comment->{count} = $count++;
$comment->{bug} = $self;
weaken($comment->{bug});
# XXX - hack for MySQL. Convert [U+....] back into its Unicode
# equivalent for characters above U+FFFF as MySQL older than 5.5.3
# cannot store them, see Bugzilla::Comment::_check_thetext().
Expand Down
9 changes: 6 additions & 3 deletions Bugzilla/Comment.pm
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ use Bugzilla::User;
use Bugzilla::Util;

use List::Util qw(first);
use Scalar::Util qw(blessed);
use Scalar::Util qw(blessed weaken isweak);

###############################
#### Initialization ####
Expand Down Expand Up @@ -232,8 +232,11 @@ sub collapsed {
sub bug {
my $self = shift;
require Bugzilla::Bug;
$self->{bug} ||= new Bugzilla::Bug($self->bug_id);
return $self->{bug};

# note $bug exists as a strong reference to keep $self->{bug} defined until the end of this method
my $bug = $self->{bug} ||= new Bugzilla::Bug($self->bug_id);
weaken($self->{bug}) unless isweak($self->{bug});
return $bug;
}

sub is_about_attachment {
Expand Down

0 comments on commit d3a58e0

Please sign in to comment.