Merge
This commit is contained in:
commit
ce9f585b48
@ -121,6 +121,10 @@ test-reprepare:
|
|||||||
|
|
||||||
test: test-unit test-ns test-pr
|
test: test-unit test-ns test-pr
|
||||||
|
|
||||||
|
smoke:
|
||||||
|
cd mysql-test ; \
|
||||||
|
@PERL@ ./mysql-test-run.pl --do-test=s
|
||||||
|
|
||||||
test-full: test test-nr test-ps
|
test-full: test test-nr test-ps
|
||||||
|
|
||||||
test-force:
|
test-force:
|
||||||
|
@ -25,6 +25,8 @@ use File::Temp qw/ tempfile tempdir /;
|
|||||||
sub _gdb {
|
sub _gdb {
|
||||||
my ($core_name)= @_;
|
my ($core_name)= @_;
|
||||||
|
|
||||||
|
print "\nTrying 'gdb' to get a backtrace\n";
|
||||||
|
|
||||||
return unless -f $core_name;
|
return unless -f $core_name;
|
||||||
|
|
||||||
my $dir = tempdir( CLEANUP => 1 );
|
my $dir = tempdir( CLEANUP => 1 );
|
||||||
@ -35,7 +37,7 @@ sub _gdb {
|
|||||||
"quit\n";
|
"quit\n";
|
||||||
|
|
||||||
# Find out name of binary that generated core
|
# Find out name of binary that generated core
|
||||||
my $list= `gdb -c $core_name -x $tmp_name -q --batch 2>&1`
|
my $list= `gdb -c $core_name -x $tmp_name -batch 2>&1`
|
||||||
or return;
|
or return;
|
||||||
|
|
||||||
my $binary;
|
my $binary;
|
||||||
@ -47,9 +49,9 @@ sub _gdb {
|
|||||||
|
|
||||||
return unless $binary;
|
return unless $binary;
|
||||||
|
|
||||||
print "Generated by '$binary'\n";
|
print " - core generated by '$binary'\n";
|
||||||
|
|
||||||
my $list= `gdb $binary -c $core_name -x $tmp_name -q --batch 2>&1`
|
my $list= `gdb $binary -c $core_name -x $tmp_name -batch 2>&1`
|
||||||
or return;
|
or return;
|
||||||
|
|
||||||
print $list, "\n";
|
print $list, "\n";
|
||||||
|
@ -20,33 +20,40 @@ use Exporter;
|
|||||||
use base "Exporter";
|
use base "Exporter";
|
||||||
our @EXPORT= qw / rmtree mkpath copytree /;
|
our @EXPORT= qw / rmtree mkpath copytree /;
|
||||||
|
|
||||||
|
|
||||||
use File::Find;
|
use File::Find;
|
||||||
use File::Path;
|
|
||||||
use File::Copy;
|
use File::Copy;
|
||||||
use Carp;
|
use Carp;
|
||||||
|
use My::Handles;
|
||||||
no warnings 'redefine';
|
|
||||||
|
|
||||||
sub rmtree {
|
sub rmtree {
|
||||||
my ($dir)= @_;
|
my ($dir)= @_;
|
||||||
|
|
||||||
#
|
|
||||||
# chmod all files to 0777 before calling rmtree
|
|
||||||
#
|
|
||||||
find( {
|
find( {
|
||||||
no_chdir => 1,
|
bydepth => 1,
|
||||||
|
no_chdir => 1,
|
||||||
wanted => sub {
|
wanted => sub {
|
||||||
chmod(0777, $_)
|
my $name= $_;
|
||||||
or warn("couldn't chmod(0777, $_): $!");
|
if (!-l $name && -d _){
|
||||||
|
return if (rmdir($name) == 1);
|
||||||
|
|
||||||
|
chmod(0777, $name) or carp("couldn't chmod(0777, $name): $!");
|
||||||
|
|
||||||
|
return if (rmdir($name) == 1);
|
||||||
|
|
||||||
|
# Failed to remove the directory, analyze
|
||||||
|
carp("Couldn't remove directory '$name': $!");
|
||||||
|
My::Handles::show_handles($name);
|
||||||
|
} else {
|
||||||
|
return if (unlink($name) == 1);
|
||||||
|
|
||||||
|
chmod(0777, $name) or carp("couldn't chmod(0777, $name): $!");
|
||||||
|
|
||||||
|
return if (unlink($name) == 1);
|
||||||
|
|
||||||
|
carp("Couldn't delete file '$name': $!");
|
||||||
|
My::Handles::show_handles($name);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
},
|
}, $dir );
|
||||||
$dir
|
|
||||||
);
|
|
||||||
|
|
||||||
|
|
||||||
# Call rmtree from File::Path
|
|
||||||
goto &File::Path::rmtree;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
69
mysql-test/lib/My/Handles.pm
Executable file
69
mysql-test/lib/My/Handles.pm
Executable file
@ -0,0 +1,69 @@
|
|||||||
|
# -*- cperl -*-
|
||||||
|
# Copyright (C) 2008 MySQL AB
|
||||||
|
#
|
||||||
|
# This program is free software; you can redistribute it and/or modify
|
||||||
|
# it under the terms of the GNU General Public License as published by
|
||||||
|
# the Free Software Foundation; version 2 of the License.
|
||||||
|
#
|
||||||
|
# This program is distributed in the hope that it will be useful,
|
||||||
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
# GNU General Public License for more details.
|
||||||
|
#
|
||||||
|
# You should have received a copy of the GNU General Public License
|
||||||
|
# along with this program; if not, write to the Free Software
|
||||||
|
# Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
||||||
|
|
||||||
|
package My::Handles;
|
||||||
|
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use Carp;
|
||||||
|
|
||||||
|
use My::Platform;
|
||||||
|
|
||||||
|
my $handle_exe;
|
||||||
|
|
||||||
|
|
||||||
|
if (IS_WINDOWS){
|
||||||
|
# Check if handle.exe is available
|
||||||
|
# Pass switch to accept the EULA to avoid hanging
|
||||||
|
# if the program hasn't been run before.
|
||||||
|
my $list= `handle.exe -? -accepteula 2>&1`;
|
||||||
|
foreach my $line (split('\n', $list))
|
||||||
|
{
|
||||||
|
$handle_exe= "$1.$2"
|
||||||
|
if ($line =~ /Handle v([0-9]*)\.([0-9]*)/);
|
||||||
|
}
|
||||||
|
if ($handle_exe){
|
||||||
|
print "Found handle.exe version $handle_exe\n";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub show_handles
|
||||||
|
{
|
||||||
|
my ($dir)= @_;
|
||||||
|
return unless $handle_exe;
|
||||||
|
return unless $dir;
|
||||||
|
|
||||||
|
$dir= native_path($dir);
|
||||||
|
|
||||||
|
# Get a list of open handles in a particular directory
|
||||||
|
my $list= `handle.exe "$dir" 2>&1` or return;
|
||||||
|
|
||||||
|
foreach my $line (split('\n', $list))
|
||||||
|
{
|
||||||
|
return if ($line =~ /No matching handles found/);
|
||||||
|
}
|
||||||
|
|
||||||
|
print "\n";
|
||||||
|
print "=" x 50, "\n";
|
||||||
|
print "Open handles in '$dir':\n";
|
||||||
|
print "$list\n";
|
||||||
|
print "=" x 50, "\n\n";
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
@ -18,7 +18,7 @@ package My::Platform;
|
|||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use File::Basename;
|
use File::Basename;
|
||||||
use My::File::Path; # Patched version of File::Path
|
use File::Path; # Patched version of File::Path
|
||||||
|
|
||||||
use base qw(Exporter);
|
use base qw(Exporter);
|
||||||
our @EXPORT= qw(IS_CYGWIN IS_WINDOWS IS_WIN32PERL
|
our @EXPORT= qw(IS_CYGWIN IS_WINDOWS IS_WIN32PERL
|
||||||
|
@ -66,7 +66,9 @@ END {
|
|||||||
for my $proc (values %running){
|
for my $proc (values %running){
|
||||||
if ( $proc->is_child($$) ){
|
if ( $proc->is_child($$) ){
|
||||||
#print "Killing: $proc\n";
|
#print "Killing: $proc\n";
|
||||||
$proc->kill();
|
if ($proc->wait_one(0)){
|
||||||
|
$proc->kill();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -146,7 +148,7 @@ sub new {
|
|||||||
print "### safe_path: ", $safe_path, " ", join(" ", @safe_args), "\n"
|
print "### safe_path: ", $safe_path, " ", join(" ", @safe_args), "\n"
|
||||||
if $verbose > 1;
|
if $verbose > 1;
|
||||||
|
|
||||||
my ($pid, $winpid)= create_process(
|
my $pid= create_process(
|
||||||
path => $safe_path,
|
path => $safe_path,
|
||||||
input => $input,
|
input => $input,
|
||||||
output => $output,
|
output => $output,
|
||||||
@ -159,7 +161,7 @@ sub new {
|
|||||||
my $proc= bless
|
my $proc= bless
|
||||||
({
|
({
|
||||||
SAFE_PID => $pid,
|
SAFE_PID => $pid,
|
||||||
SAFE_WINPID => $winpid,
|
SAFE_WINPID => $pid, # Inidicates this is always a real process
|
||||||
SAFE_NAME => $name,
|
SAFE_NAME => $name,
|
||||||
SAFE_SHUTDOWN => $shutdown,
|
SAFE_SHUTDOWN => $shutdown,
|
||||||
PARENT => $$,
|
PARENT => $$,
|
||||||
@ -302,6 +304,18 @@ sub shutdown {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
sub _winpid ($) {
|
||||||
|
my ($pid)= @_;
|
||||||
|
|
||||||
|
# In win32 perl, the pid is already the winpid
|
||||||
|
return $pid unless IS_CYGWIN;
|
||||||
|
|
||||||
|
# In cygwin, the pid is the pseudo process ->
|
||||||
|
# get the real winpid of my_safe_process
|
||||||
|
return Cygwin::pid_to_winpid($pid);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# Tell the process to die as fast as possible
|
# Tell the process to die as fast as possible
|
||||||
#
|
#
|
||||||
@ -311,22 +325,24 @@ sub start_kill {
|
|||||||
_verbose("start_kill: $self");
|
_verbose("start_kill: $self");
|
||||||
my $ret= 1;
|
my $ret= 1;
|
||||||
|
|
||||||
my $pid;
|
my $pid= $self->{SAFE_PID};
|
||||||
|
die "INTERNAL ERROR: no pid" unless defined $pid;
|
||||||
|
|
||||||
if (IS_WINDOWS and defined $self->{SAFE_WINPID})
|
if (IS_WINDOWS and defined $self->{SAFE_WINPID})
|
||||||
{
|
{
|
||||||
die "INTERNAL ERROR: no safe_kill" unless defined $safe_kill;
|
die "INTERNAL ERROR: no safe_kill" unless defined $safe_kill;
|
||||||
die "INTERNAL ERROR: no winpid" unless defined $self->{SAFE_WINPID};
|
|
||||||
|
|
||||||
# Use my_safe_kill to tell my_safe_process
|
my $winpid= _winpid($pid);
|
||||||
# it's time to kill it's child and return
|
$ret= system($safe_kill, $winpid) >> 8;
|
||||||
$pid= $self->{SAFE_WINPID};
|
|
||||||
$ret= system($safe_kill, $pid) >> 8;
|
if ($ret == 3){
|
||||||
if (IS_CYGWIN and $ret == 3)
|
print "Couldn't open the winpid: $winpid ",
|
||||||
{
|
"for pid: $pid, try one more time\n";
|
||||||
print "safe_process is gone, kickstart the fake process\n";
|
sleep(1);
|
||||||
if (kill(15, $self->{SAFE_PID}) != 1){
|
$winpid= _winpid($pid);
|
||||||
print STDERR "Failed to kickstart the fake process\n";
|
$ret= system($safe_kill, $winpid) >> 8;
|
||||||
}
|
print "Couldn't open the winpid: $winpid ",
|
||||||
|
"for pid: $pid, continue and see what happens...\n";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
@ -33,30 +33,6 @@ use base qw(Exporter);
|
|||||||
our @EXPORT= qw(create_process);
|
our @EXPORT= qw(create_process);
|
||||||
|
|
||||||
|
|
||||||
sub winpid {
|
|
||||||
my ($pid)= @_;
|
|
||||||
|
|
||||||
return undef unless $^O eq "cygwin";
|
|
||||||
|
|
||||||
# The child get a new winpid when the exec takes
|
|
||||||
# place, wait for that to happen
|
|
||||||
my $winpid;
|
|
||||||
my $delay= 0;
|
|
||||||
do
|
|
||||||
{
|
|
||||||
# Yield to the child
|
|
||||||
select(undef, undef, undef, $delay);
|
|
||||||
# Increase the delay slightly for each loop
|
|
||||||
$delay += 0.000001;
|
|
||||||
|
|
||||||
$winpid= Cygwin::pid_to_winpid($pid);
|
|
||||||
|
|
||||||
} until ($winpid != $pid);
|
|
||||||
|
|
||||||
return $winpid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#
|
#
|
||||||
# safe_fork
|
# safe_fork
|
||||||
@ -179,7 +155,7 @@ sub create_process {
|
|||||||
or croak("unable to reestablish STDIN");
|
or croak("unable to reestablish STDIN");
|
||||||
#printf STDERR "stdin %d, stdout %d, stderr %d\n",
|
#printf STDERR "stdin %d, stdout %d, stderr %d\n",
|
||||||
# fileno STDIN, fileno STDOUT, fileno STDERR;
|
# fileno STDIN, fileno STDOUT, fileno STDERR;
|
||||||
return wantarray ? ($pid, $pid) : $pid;
|
return $pid;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -190,7 +166,7 @@ sub create_process {
|
|||||||
# Parent
|
# Parent
|
||||||
$pipe->reader();
|
$pipe->reader();
|
||||||
my $line= <$pipe>; # Wait for child to say it's ready
|
my $line= <$pipe>; # Wait for child to say it's ready
|
||||||
return wantarray ? ($pid, winpid($pid)) : $pid;
|
return $pid;
|
||||||
}
|
}
|
||||||
|
|
||||||
$SIG{INT}= 'DEFAULT';
|
$SIG{INT}= 'DEFAULT';
|
||||||
|
@ -49,12 +49,25 @@ int main(int argc, const char** argv )
|
|||||||
while ((shutdown_event=
|
while ((shutdown_event=
|
||||||
OpenEvent(EVENT_MODIFY_STATE, FALSE, safe_process_name)) == NULL)
|
OpenEvent(EVENT_MODIFY_STATE, FALSE, safe_process_name)) == NULL)
|
||||||
{
|
{
|
||||||
|
/*
|
||||||
|
Check if the process is alive, otherwise there is really
|
||||||
|
no idea to retry the open of the event
|
||||||
|
*/
|
||||||
|
HANDLE process;
|
||||||
|
if ((process= OpenProcess(SYNCHRONIZE, FALSE, pid)) == NULL)
|
||||||
|
{
|
||||||
|
fprintf(stderr, "Could not open event or process %d, error: %d\n",
|
||||||
|
pid, GetLastError());
|
||||||
|
exit(3);
|
||||||
|
}
|
||||||
|
CloseHandle(process);
|
||||||
|
|
||||||
if (retry_open_event--)
|
if (retry_open_event--)
|
||||||
Sleep(100);
|
Sleep(100);
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
fprintf(stderr, "Failed to open shutdown_event '%s', error: %d\n",
|
fprintf(stderr, "Failed to open shutdown_event '%s', error: %d\n",
|
||||||
safe_process_name, GetLastError());
|
safe_process_name, GetLastError());
|
||||||
exit(3);
|
exit(3);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -4244,6 +4244,7 @@ sub start_check_testcase ($$$) {
|
|||||||
error => $errfile,
|
error => $errfile,
|
||||||
args => \$args,
|
args => \$args,
|
||||||
user_data => $errfile,
|
user_data => $errfile,
|
||||||
|
verbose => $opt_verbose,
|
||||||
);
|
);
|
||||||
|
|
||||||
mtr_report("Started $proc");
|
mtr_report("Started $proc");
|
||||||
|
Loading…
x
Reference in New Issue
Block a user