mirror of
https://github.com/MariaDB/server.git
synced 2025-07-27 18:02:13 +03:00
Merge branch '11.2' into 11.4
This commit is contained in:
28
mysql-test/include/have_cgroupv2.inc
Normal file
28
mysql-test/include/have_cgroupv2.inc
Normal file
@ -0,0 +1,28 @@
|
||||
--source include/linux.inc
|
||||
--error 0,1
|
||||
perl;
|
||||
use strict;
|
||||
use warnings;
|
||||
use File::Spec;
|
||||
|
||||
# Read the cgroup file
|
||||
my $cgroup_file = '/proc/self/cgroup';
|
||||
open my $fh, '<', $cgroup_file or exit 1;
|
||||
my $line = <$fh>;
|
||||
close $fh;
|
||||
|
||||
# Process the cgroup file content
|
||||
$line =~ s/^0:://;
|
||||
chomp($line);
|
||||
|
||||
# Construct the path
|
||||
my $path = File::Spec->catdir('/sys/fs/cgroup', $line, 'memory.pressure');
|
||||
|
||||
# Check if the file is writable exists
|
||||
exit 0 if -w $path;
|
||||
exit 1;
|
||||
EOF
|
||||
if ($errno)
|
||||
{
|
||||
--skip Requires cgroupv2
|
||||
}
|
201
mysql-test/include/search_condition.inc
Normal file
201
mysql-test/include/search_condition.inc
Normal file
@ -0,0 +1,201 @@
|
||||
--echo #
|
||||
--echo # WHERE <search condition>
|
||||
--echo #
|
||||
|
||||
let datatype=`SELECT DATA_TYPE FROM INFORMATION_SCHEMA.COLUMNS
|
||||
WHERE TABLE_NAME='t0' AND COLUMN_NAME='c'`;
|
||||
let use_string_func=0;
|
||||
let use_field=1;
|
||||
let update_source=c+11;
|
||||
|
||||
if ($datatype == 'varchar')
|
||||
{
|
||||
let use_string_func=1;
|
||||
}
|
||||
|
||||
if ($datatype == 'datetime')
|
||||
{
|
||||
let update_source=c+0.1;
|
||||
}
|
||||
|
||||
if ($datatype == 'inet6')
|
||||
{
|
||||
let use_field=0;
|
||||
let update_source=concat(c,'77');
|
||||
}
|
||||
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
if ($use_field)
|
||||
{
|
||||
SELECT * FROM t1 WHERE c;
|
||||
}
|
||||
SELECT * FROM t1 WHERE c IS FALSE;
|
||||
SELECT * FROM t1 WHERE c IS TRUE;
|
||||
SELECT * FROM t1 WHERE COALESCE(c);
|
||||
if ($use_string_func)
|
||||
{
|
||||
SELECT * FROM t1 WHERE CONCAT(c);
|
||||
SELECT * FROM t1 WHERE LEFT(c,100);
|
||||
}
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # HAVING <search condition>
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
if ($use_field)
|
||||
{
|
||||
SELECT COALESCE(c,c) AS c2 FROM t1 GROUP BY c2 HAVING c2;
|
||||
}
|
||||
SELECT COALESCE(c,c) AS c2 FROM t1 GROUP BY c2 HAVING c2 IS FALSE;
|
||||
SELECT COALESCE(c,c) AS c2 FROM t1 GROUP BY c2 HAVING c2 IS TRUE;
|
||||
SELECT COALESCE(c,c) AS c2 FROM t1 GROUP BY c2 HAVING COALESCE(c2);
|
||||
if ($use_string_func)
|
||||
{
|
||||
SELECT CONCAT(c,'0') AS c2 FROM t1 GROUP BY c2 HAVING LEFT(c2,100);
|
||||
}
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # <join condition> := ON <search condition>
|
||||
--echo #
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
if ($use_field)
|
||||
{
|
||||
SELECT t1.c FROM t1 JOIN t1 AS t2 ON (t1.c);
|
||||
}
|
||||
SELECT t1.c FROM t1 JOIN t1 AS t2 ON (t1.c IS FALSE);
|
||||
SELECT t1.c FROM t1 JOIN t1 AS t2 ON (t1.c IS TRUE);
|
||||
SELECT t1.c FROM t1 JOIN t1 AS t2 ON (COALESCE(t1.c));
|
||||
if ($use_string_func)
|
||||
{
|
||||
SELECT t1.c FROM t1 JOIN t1 AS t2 ON (CONCAT(t1.c));
|
||||
}
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # <delete statement: searched>
|
||||
--echo # DELETE FROM <target table> [ WHERE <search condition> ]
|
||||
--echo #
|
||||
|
||||
if ($use_field)
|
||||
{
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
DELETE FROM t1 WHERE c;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
}
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
DELETE FROM t1 WHERE c IS FALSE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
DELETE FROM t1 WHERE c IS TRUE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
DELETE FROM t1 WHERE COALESCE(c);
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
if ($use_string_func)
|
||||
{
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
DELETE FROM t1 WHERE CONCAT(c);
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
}
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # <update statement: searched>
|
||||
--echo # UPDATE <target table> SET <set clause list> [ WHERE <search condition> ]
|
||||
|
||||
if ($use_field)
|
||||
{
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
eval UPDATE t1 SET c=$update_source WHERE c;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
}
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
eval UPDATE t1 SET c=$update_source WHERE c IS FALSE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
eval UPDATE t1 SET c=$update_source WHERE c IS TRUE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
eval UPDATE t1 SET c=$update_source WHERE COALESCE(c);
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
if ($use_string_func)
|
||||
{
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
eval UPDATE t1 SET c=$update_source WHERE COALESCE(c);
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
}
|
||||
|
||||
--echo #
|
||||
--echo # <check constraint definition>
|
||||
--echo # CHECK <left paren> <search condition> <right paren>
|
||||
|
||||
if ($use_field)
|
||||
{
|
||||
CREATE TABLE t1 LIKE t0;
|
||||
ALTER TABLE t1 ADD CONSTRAINT check0 CHECK(c);
|
||||
--error ER_CONSTRAINT_FAILED
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE NOT c;
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
}
|
||||
|
||||
CREATE TABLE t1 LIKE t0;
|
||||
ALTER TABLE t1 ADD CONSTRAINT check0 CHECK(c IS FALSE);
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS FALSE;
|
||||
--error ER_CONSTRAINT_FAILED
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS TRUE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 LIKE t0;
|
||||
ALTER TABLE t1 ADD CONSTRAINT check0 CHECK(c IS TRUE);
|
||||
--error ER_CONSTRAINT_FAILED
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS FALSE;
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS TRUE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
CREATE TABLE t1 LIKE t0;
|
||||
ALTER TABLE t1 ADD CONSTRAINT check0 CHECK(COALESCE(c));
|
||||
--error ER_CONSTRAINT_FAILED
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS FALSE;
|
||||
INSERT INTO t1 SELECT * FROM t0 WHERE c IS TRUE;
|
||||
SELECT * FROM t1;
|
||||
DROP TABLE t1;
|
||||
|
||||
|
||||
--echo #
|
||||
--echo # <case expression>
|
||||
--echo # WHEN <search condition> THEN <result>
|
||||
|
||||
CREATE TABLE t1 AS SELECT * FROM t0;
|
||||
SELECT c, CASE WHEN c THEN 'true' ELSE 'false' END AS c2 FROM t1;
|
||||
SELECT c, CASE WHEN COALESCE(c) THEN 'true' ELSE 'false' END AS c2 FROM t1;
|
||||
DROP TABLE t1;
|
@ -18,6 +18,10 @@
|
||||
# Optionally, SEARCH_ABORT can be set to "FOUND" or "NOT FOUND" and this
|
||||
# will abort if the search result doesn't match the requested one.
|
||||
#
|
||||
# Optionally, SEARCH_WAIT can be set to "FOUND" or "NOT FOUND", and this
|
||||
# will wait for the condition to occur. The timeout can be set in
|
||||
# SEARCH_TIMEOUT, default is 60 seconds.
|
||||
#
|
||||
# Optionally, SEARCH_OUTPUT can be set to control the format of output.
|
||||
# Supported formats:
|
||||
# - (default) : "FOUND n /pattern/ in FILE " or "NOT FOUND ..."
|
||||
@ -55,31 +59,50 @@ perl;
|
||||
my @search_files= glob($ENV{SEARCH_FILE});
|
||||
my $search_pattern= $ENV{SEARCH_PATTERN} or die "SEARCH_PATTERN not set";
|
||||
my $search_range= $ENV{SEARCH_RANGE};
|
||||
my $content;
|
||||
foreach my $search_file (@search_files) {
|
||||
open(FILE, '<', $search_file) || die("Can't open file $search_file: $!");
|
||||
my $file_content;
|
||||
if ($search_range > 0) {
|
||||
read(FILE, $file_content, $search_range, 0);
|
||||
} elsif ($search_range < 0) {
|
||||
my $size= -s $search_file;
|
||||
$search_range = -$size if $size > -$search_range;
|
||||
seek(FILE, $search_range, 2);
|
||||
read(FILE, $file_content, -$search_range, 0);
|
||||
} else {
|
||||
while(<FILE>) { # error log
|
||||
if (/^CURRENT_TEST:/) {
|
||||
$content='';
|
||||
my $timeout= $ENV{SEARCH_TIMEOUT} || 60;
|
||||
my @matches;
|
||||
my $res;
|
||||
|
||||
my $start_time= time();
|
||||
for (;;) {
|
||||
my $content;
|
||||
foreach my $search_file (@search_files) {
|
||||
open(FILE, '<', $search_file) || die("Can't open file $search_file: $!");
|
||||
my $file_content;
|
||||
if ($search_range > 0) {
|
||||
read(FILE, $file_content, $search_range, 0);
|
||||
} elsif ($search_range < 0) {
|
||||
my $size= -s $search_file;
|
||||
$search_range = -$size if $size > -$search_range;
|
||||
seek(FILE, $search_range, 2);
|
||||
read(FILE, $file_content, -$search_range, 0);
|
||||
} else {
|
||||
$content.=$_;
|
||||
while(<FILE>) { # error log
|
||||
if (/^CURRENT_TEST:/) {
|
||||
$content='';
|
||||
} else {
|
||||
$content.=$_;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
close(FILE);
|
||||
$content.= $file_content;
|
||||
}
|
||||
close(FILE);
|
||||
$content.= $file_content;
|
||||
@matches= ($content =~ /$search_pattern/gs);
|
||||
$res=@matches ? "FOUND " . scalar(@matches) : "NOT FOUND";
|
||||
|
||||
if (($ENV{SEARCH_WAIT} eq 'FOUND' && $res eq 'NOT FOUND') ||
|
||||
($ENV{SEARCH_WAIT} eq 'NOT FOUND' && $res =~ m{^FOUND })) {
|
||||
if (time() - $start_time < $timeout) {
|
||||
# Millisceond sleep emulated with select
|
||||
select(undef, undef, undef, 0.1);
|
||||
next;
|
||||
}
|
||||
die "Timeout waiting for $ENV{SEARCH_WAIT} ".
|
||||
"for /$search_pattern/ in $ENV{SEARCH_FILE}\n";
|
||||
}
|
||||
last;
|
||||
}
|
||||
my @matches= ($content =~ /$search_pattern/gs);
|
||||
my $res=@matches ? "FOUND " . scalar(@matches) : "NOT FOUND";
|
||||
|
||||
$ENV{SEARCH_FILE} =~ s{^.*?([^/\\]+)$}{$1};
|
||||
|
||||
|
Reference in New Issue
Block a user