summaryrefslogtreecommitdiffstats
path: root/mysql-test/suite.pm
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:24:36 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 12:24:36 +0000
commit06eaf7232e9a920468c0f8d74dcf2fe8b555501c (patch)
treee2c7b5777f728320e5b5542b6213fd3591ba51e2 /mysql-test/suite.pm
parentInitial commit. (diff)
downloadmariadb-06eaf7232e9a920468c0f8d74dcf2fe8b555501c.tar.xz
mariadb-06eaf7232e9a920468c0f8d74dcf2fe8b555501c.zip
Adding upstream version 1:10.11.6.upstream/1%10.11.6
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'mysql-test/suite.pm')
-rw-r--r--mysql-test/suite.pm119
1 files changed, 119 insertions, 0 deletions
diff --git a/mysql-test/suite.pm b/mysql-test/suite.pm
new file mode 100644
index 00000000..f30cc5ec
--- /dev/null
+++ b/mysql-test/suite.pm
@@ -0,0 +1,119 @@
+package My::Suite::Main;
+use My::Platform;
+
+@ISA = qw(My::Suite);
+
+sub skip_combinations {
+ my @combinations;
+
+ # disable innodb combinations for configurations that were not built
+ push @combinations, 'innodb_plugin' unless $ENV{HA_INNODB_SO};
+
+ push @combinations, 'innodb' unless $::mysqld_variables{'innodb'} eq "ON";
+
+ my %skip = ( 'include/have_innodb.combinations' => [ @combinations ]);
+
+ $skip{'include/innodb_encrypt_log.combinations'} = [ 'crypt' ]
+ unless $ENV{DEBUG_KEY_MANAGEMENT_SO};
+
+ # don't run tests for the wrong platform
+ if (IS_WINDOWS) {
+ $skip{'include/platform.combinations'} = [ 'aix', 'unix' ];
+ } elsif (IS_AIX) {
+ $skip{'include/platform.combinations'} = [ 'win', 'unix' ];
+ } else {
+ $skip{'include/platform.combinations'} = [ 'aix', 'win' ];
+ }
+
+ if ( $::opt_ps_protocol ) {
+ $skip{'include/protocol.combinations'} = [ 'nm' ];
+ } else {
+ $skip{'include/protocol.combinations'} = [ 'ps' ];
+ }
+
+ $skip{'include/maybe_debug.combinations'} =
+ [ defined $::mysqld_variables{'debug-dbug'} ? 'release' : 'debug' ];
+
+ $skip{'include/have_debug.inc'} = 'Requires debug build'
+ unless defined $::mysqld_variables{'debug-dbug'};
+
+ # and for the wrong word size
+ # check for exact values, in case the default changes to be small everywhere
+ my $longsysvar= $::mysqld_variables{'max-binlog-stmt-cache-size'};
+ my %val_map= (
+ '4294963200' => '64bit', # remember, it shows *what configuration to skip*
+ '18446744073709547520' => '32bit'
+ );
+ die "unknown value max-binlog-stmt-cache-size=$longsysvar" unless $val_map{$longsysvar};
+ $skip{'include/word_size.combinations'} = [ $val_map{$longsysvar} ];
+
+ # as a special case, disable certain include files as a whole
+ $skip{'include/not_embedded.inc'} = 'Not run for embedded server'
+ if $::opt_embedded_server;
+
+ $skip{'include/have_example_plugin.inc'} = 'Need example plugin'
+ unless $ENV{HA_EXAMPLE_SO};
+
+ $skip{'include/not_windows.inc'} = 'Requires not Windows' if IS_WINDOWS;
+ $skip{'include/not_aix.inc'} = 'Requires not AIX' if IS_AIX;
+
+ $skip{'main/plugin_loaderr.test'} = 'needs compiled-in innodb'
+ unless $::mysqld_variables{'innodb'} eq "ON";
+
+ # disable tests that use ipv6, if unsupported
+ sub ipv6_ok() {
+ use Socket;
+ return 0 unless socket my $sock, PF_INET6, SOCK_STREAM, getprotobyname('tcp');
+ $!="";
+ # eval{}, if there's no Socket::sockaddr_in6 at all, old Perl installation <5.14
+ eval { bind $sock, sockaddr_in6($::baseport, Socket::IN6ADDR_LOOPBACK) };
+ return $@ eq "" && $! eq ""
+ }
+ $skip{'include/check_ipv6.inc'} = 'No IPv6' unless ipv6_ok();
+
+ # SSL is complicated
+ my $ssl_lib= $::mysqld_variables{'version-ssl-library'};
+ my $openssl_ver= $ssl_lib =~ /OpenSSL (\S+)/ ? $1 : "";
+
+ $skip{'include/have_ssl_communication.inc'} =
+ $skip{'include/have_ssl_crypto_functs.inc'} = 'Requires SSL' unless $ssl_lib;
+
+ $skip{'main/openssl_6975.test'} = 'no or wrong openssl version'
+ unless $openssl_ver ge "1.0.1d" and $openssl_ver lt "1.1.1";
+
+ $skip{'main/ssl_7937.combinations'} = [ 'x509v3' ]
+ unless $ssl_lib =~ /WolfSSL/ or $openssl_ver ge "1.0.2";
+
+ $skip{'main/ssl_verify_ip.test'} = 'x509v3 support required'
+ unless $openssl_ver ge "1.0.2";
+
+ sub utf8_command_line_ok() {
+ if (IS_WINDOWS) {
+ # Can use UTF8 on command line since Windows 10 1903 (10.0.18362)
+ # or if OS codepage is set to UTF8
+ my($os_name, $os_major, $os_minor, $os_build, $os_id) = Win32::GetOSVersion();
+ if($os_major lt 10){
+ return 0;
+ } elsif($os_major gt 10 or $os_minor gt 0 or $os_build ge 18362){
+ return 1;
+ } elsif(Win32::GetACP() eq 65001) {
+ return 1;
+ }
+ return 0;
+ }
+ return 1;
+ }
+
+ $skip{'include/check_utf8_cli.inc'} = 'No utf8 command line support'
+ unless utf8_command_line_ok();
+
+ $skip{'include/no_utf8_cli.inc'} = 'Not tested with utf8 command line support'
+ unless !utf8_command_line_ok();
+
+ $skip{'include/check_windows_admin.inc'} = 'Requires admin privileges'
+ unless IS_WINDOWS and Win32::IsAdminUser();
+
+ %skip;
+}
+
+bless { };