Server IP : 185.86.78.101 / Your IP : 216.73.216.124 Web Server : Apache System : Linux 675867-vds-valikoshka1996.gmhost.pp.ua 5.4.0-150-generic #167-Ubuntu SMP Mon May 15 17:35:05 UTC 2023 x86_64 User : www ( 1000) PHP Version : 7.4.33 Disable Function : passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /www/server/mysql/mysql-test/lib/My/ |
Upload File : |
# -*- cperl -*- # Copyright (c) 2007, 2022, Oracle and/or its affiliates. # # This program is free software; you can redistribute it and/or modify # it under the terms of the GNU General Public License, version 2.0, # as published by the Free Software Foundation. # # This program is also distributed with certain software (including # but not limited to OpenSSL) that is licensed under separate terms, # as designated in a particular file or component or in included license # documentation. The authors of MySQL hereby grant you an additional # permission to link the program and your derivative works with the # separately licensed software that they have included with MySQL. # # 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, version 2.0, 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::Exec; use strict; use warnings; use Carp; use File::Basename; use IO::File; use base qw(Exporter); our @EXPORT= qw(exec_print_on_error); # Generate a logfile name from a command sub get_logfile_name { my $cmd = shift; # Get logfile name my @cmd_parts = split(' ', $cmd); my $logfile_base = fileparse($cmd_parts[0]); $logfile_base =~ s/[^a-zA-Z0-9_]*//g; my $logfile_name = ""; my $log_dir = $ENV{MYSQLTEST_VARDIR}; for my $i (1..100) { my $proposed_logfile_name = "$log_dir/$logfile_base" . '_' . $i . ".log"; if (! -f $proposed_logfile_name) { # We can use this file name $logfile_name = $proposed_logfile_name; last; } } return $logfile_name; } # Show the last "max_lines" from file sub show_last_lines_from_file { my ($filename, $max_lines) = @_; my $F = IO::File->new($filename, "r") or print "Failed to open file '$filename' for reading: $!\n" and return; my @input = <$F>; my $lines = scalar(@input); $lines = $max_lines if $lines > $max_lines; print "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n"; print "Last '$lines' lines of output from command:\n"; foreach my $line (splice(@input, -$lines)) { print $line; } print "!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!!\n"; $F->close(); } # Extract the command name with args, ignoring its location sub get_command_name { my $cmd = shift; my @cmd_parts = split(' ', $cmd); my $cmd_base_name = fileparse($cmd_parts[0]); my $cmd_base_with_args = substr($cmd , index($cmd, $cmd_base_name)); return $cmd_base_with_args; } # # exec_print_on_error - executes command, and prints n last lines of output # from the command only if the command fails. If the command runs # successfully, no output is written. # # Parameters: # cmd - the command to run # max_lines - the maximum number of lines of output to show on error (default 200) # Returns: # 1 on success, 0 on error. # Example: # use My::Exec; # my $res = exec_print_on_error("./mtr --suite=ndb ndb_dd_varsize"); # sub exec_print_on_error { my $cmd = shift; my $max_lines = shift || 200; my $logfile_name = get_logfile_name($cmd); my $cmd_base_name = get_command_name($cmd); # Redirect stdout and stderr of command to log file $cmd .= " > $logfile_name 2>&1"; # Execute command print "Running '$cmd_base_name'\n"; system($cmd); print "Result of '$cmd_base_name': $?\n"; if ($? == 0) { # Test program suceeded return 1; } # Test program failed if ($? == -1) { # Failed to execute program print "Failed to execute '$cmd': $!\n"; } elsif ($?) { # Test program failed my $sig = $? & 127; my $return = $? >> 8; print "Command that failed: '$cmd'\n"; print "Test program killed by signal $sig\n" if $sig; print "Test program failed with error $return\n" if $return; # Show the "max_lines" last lines from the log file show_last_lines_from_file($logfile_name, $max_lines); } return 0; }