Skip to content

Commit

Permalink
Make sure to use mariadb* commands
Browse files Browse the repository at this point in the history
  • Loading branch information
fauust committed Feb 29, 2024
1 parent 313449c commit eaacf38
Show file tree
Hide file tree
Showing 4 changed files with 46 additions and 62 deletions.
54 changes: 27 additions & 27 deletions scripts/bash_lib.sh
Original file line number Diff line number Diff line change
Expand Up @@ -299,25 +299,25 @@ upgrade_test_type() {
check_mariadb_server_and_create_structures() {
if [ "$prev_major_version" != 10.3 ]; then
# 10.4+ uses unix_socket by default
sudo mysql -e "set password=password('rootpass')"
sudo mariadb -e "set password=password('rootpass')"
else
# Even without unix_socket, on some of VMs the password might be not pre-created as expected. This command should normally fail.
mysql -uroot -e "set password = password('rootpass')" >>/dev/null 2>&1
mariadb -uroot -e "set password = password('rootpass')" >>/dev/null 2>&1
fi

# All the commands below should succeed
set -e
mysql -uroot -prootpass -e "CREATE DATABASE db"
mysql -uroot -prootpass -e "CREATE TABLE db.t_innodb(a1 SERIAL, c1 CHAR(8)) ENGINE=InnoDB; INSERT INTO db.t_innodb VALUES (1,'foo'),(2,'bar')"
mysql -uroot -prootpass -e "CREATE TABLE db.t_myisam(a2 SERIAL, c2 CHAR(8)) ENGINE=MyISAM; INSERT INTO db.t_myisam VALUES (1,'foo'),(2,'bar')"
mysql -uroot -prootpass -e "CREATE TABLE db.t_aria(a3 SERIAL, c3 CHAR(8)) ENGINE=Aria; INSERT INTO db.t_aria VALUES (1,'foo'),(2,'bar')"
mysql -uroot -prootpass -e "CREATE TABLE db.t_memory(a4 SERIAL, c4 CHAR(8)) ENGINE=MEMORY; INSERT INTO db.t_memory VALUES (1,'foo'),(2,'bar')"
mysql -uroot -prootpass -e "CREATE ALGORITHM=MERGE VIEW db.v_merge AS SELECT * FROM db.t_innodb, db.t_myisam, db.t_aria"
mysql -uroot -prootpass -e "CREATE ALGORITHM=TEMPTABLE VIEW db.v_temptable AS SELECT * FROM db.t_innodb, db.t_myisam, db.t_aria"
mysql -uroot -prootpass -e "CREATE PROCEDURE db.p() SELECT * FROM db.v_merge"
mysql -uroot -prootpass -e "CREATE FUNCTION db.f() RETURNS INT DETERMINISTIC RETURN 1"
mariadb -uroot -prootpass -e "CREATE DATABASE db"
mariadb -uroot -prootpass -e "CREATE TABLE db.t_innodb(a1 SERIAL, c1 CHAR(8)) ENGINE=InnoDB; INSERT INTO db.t_innodb VALUES (1,'foo'),(2,'bar')"
mariadb -uroot -prootpass -e "CREATE TABLE db.t_myisam(a2 SERIAL, c2 CHAR(8)) ENGINE=MyISAM; INSERT INTO db.t_myisam VALUES (1,'foo'),(2,'bar')"
mariadb -uroot -prootpass -e "CREATE TABLE db.t_aria(a3 SERIAL, c3 CHAR(8)) ENGINE=Aria; INSERT INTO db.t_aria VALUES (1,'foo'),(2,'bar')"
mariadb -uroot -prootpass -e "CREATE TABLE db.t_memory(a4 SERIAL, c4 CHAR(8)) ENGINE=MEMORY; INSERT INTO db.t_memory VALUES (1,'foo'),(2,'bar')"
mariadb -uroot -prootpass -e "CREATE ALGORITHM=MERGE VIEW db.v_merge AS SELECT * FROM db.t_innodb, db.t_myisam, db.t_aria"
mariadb -uroot -prootpass -e "CREATE ALGORITHM=TEMPTABLE VIEW db.v_temptable AS SELECT * FROM db.t_innodb, db.t_myisam, db.t_aria"
mariadb -uroot -prootpass -e "CREATE PROCEDURE db.p() SELECT * FROM db.v_merge"
mariadb -uroot -prootpass -e "CREATE FUNCTION db.f() RETURNS INT DETERMINISTIC RETURN 1"
if [[ $test_mode == "columnstore" ]]; then
if ! mysql -uroot -prootpass -e "CREATE TABLE db.t_columnstore(a INT, c VARCHAR(8)) ENGINE=ColumnStore; SHOW CREATE TABLE db.t_columnstore; INSERT INTO db.t_columnstore VALUES (1,'foo'),(2,'bar')"; then
if ! mariadb -uroot -prootpass -e "CREATE TABLE db.t_columnstore(a INT, c VARCHAR(8)) ENGINE=ColumnStore; SHOW CREATE TABLE db.t_columnstore; INSERT INTO db.t_columnstore VALUES (1,'foo'),(2,'bar')"; then
get_columnstore_logs
exit 1
fi
Expand All @@ -327,24 +327,24 @@ check_mariadb_server_and_create_structures() {

check_mariadb_server_and_verify_structures() {
# Print "have_xx" capabilitites for the new server
mysql -uroot -prootpass -e "select 'Stat' t, variable_name name, variable_value val from information_schema.global_status where variable_name like '%have%' union select 'Vars' t, variable_name name, variable_value val from information_schema.global_variables where variable_name like '%have%' order by t, name"
mariadb -uroot -prootpass -e "select 'Stat' t, variable_name name, variable_value val from information_schema.global_status where variable_name like '%have%' union select 'Vars' t, variable_name name, variable_value val from information_schema.global_variables where variable_name like '%have%' order by t, name"
# All the commands below should succeed
set -e
mysql -uroot -prootpass -e "select @@version, @@version_comment"
mysql -uroot -prootpass -e "SHOW TABLES IN db"
mysql -uroot -prootpass -e "SELECT * FROM db.t_innodb; INSERT INTO db.t_innodb VALUES (3,'foo'),(4,'bar')"
mysql -uroot -prootpass -e "SELECT * FROM db.t_myisam; INSERT INTO db.t_myisam VALUES (3,'foo'),(4,'bar')"
mysql -uroot -prootpass -e "SELECT * FROM db.t_aria; INSERT INTO db.t_aria VALUES (3,'foo'),(4,'bar')"
mariadb -uroot -prootpass -e "select @@version, @@version_comment"
mariadb -uroot -prootpass -e "SHOW TABLES IN db"
mariadb -uroot -prootpass -e "SELECT * FROM db.t_innodb; INSERT INTO db.t_innodb VALUES (3,'foo'),(4,'bar')"
mariadb -uroot -prootpass -e "SELECT * FROM db.t_myisam; INSERT INTO db.t_myisam VALUES (3,'foo'),(4,'bar')"
mariadb -uroot -prootpass -e "SELECT * FROM db.t_aria; INSERT INTO db.t_aria VALUES (3,'foo'),(4,'bar')"
bb_log_info "If the next INSERT fails with a duplicate key error,"
bb_log_info "it is likely because the server was not upgraded or restarted after upgrade"
mysql -uroot -prootpass -e "SELECT * FROM db.t_memory; INSERT INTO db.t_memory VALUES (1,'foo'),(2,'bar')"
mysql -uroot -prootpass -e "SELECT COUNT(*) FROM db.v_merge"
mysql -uroot -prootpass -e "SELECT COUNT(*) FROM db.v_temptable"
mysql -uroot -prootpass -e "CALL db.p()"
mysql -uroot -prootpass -e "SELECT db.f()"
mariadb -uroot -prootpass -e "SELECT * FROM db.t_memory; INSERT INTO db.t_memory VALUES (1,'foo'),(2,'bar')"
mariadb -uroot -prootpass -e "SELECT COUNT(*) FROM db.v_merge"
mariadb -uroot -prootpass -e "SELECT COUNT(*) FROM db.v_temptable"
mariadb -uroot -prootpass -e "CALL db.p()"
mariadb -uroot -prootpass -e "SELECT db.f()"

if [[ $test_mode == "columnstore" ]]; then
if ! mysql -uroot -prootpass -e "SELECT * FROM db.t_columnstore; INSERT INTO db.t_columnstore VALUES (3,'foo'),(4,'bar')"; then
if ! mariadb -uroot -prootpass -e "SELECT * FROM db.t_columnstore; INSERT INTO db.t_columnstore VALUES (3,'foo'),(4,'bar')"; then
get_columnstore_logs
exit 1
fi
Expand All @@ -365,9 +365,9 @@ control_mariadb_server() {
}

store_mariadb_server_info() {
mysql -uroot -prootpass --skip-column-names -e "select @@version" | awk -F'-' '{ print $1 }' >"/tmp/version.$1"
mysql -uroot -prootpass --skip-column-names -e "select engine, support, transactions, savepoints from information_schema.engines" | sort >"/tmp/engines.$1"
mysql -uroot -prootpass --skip-column-names -e "select plugin_name, plugin_status, plugin_type, plugin_library, plugin_license from information_schema.all_plugins" | sort >"/tmp/plugins.$1"
mariadb -uroot -prootpass --skip-column-names -e "select @@version" | awk -F'-' '{ print $1 }' >"/tmp/version.$1"
mariadb -uroot -prootpass --skip-column-names -e "select engine, support, transactions, savepoints from information_schema.engines" | sort >"/tmp/engines.$1"
mariadb -uroot -prootpass --skip-column-names -e "select plugin_name, plugin_status, plugin_type, plugin_library, plugin_license from information_schema.all_plugins" | sort >"/tmp/plugins.$1"
}

check_upgraded_versions() {
Expand Down
21 changes: 6 additions & 15 deletions scripts/deb-install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -99,17 +99,8 @@ if [[ -n $spider_package_list ]]; then
sudo sh -c "DEBIAN_FRONTEND=noninteractive MYSQLD_STARTUP_TIMEOUT=180 apt-get install -y $spider_package_list"
fi

# Unix socket (after 10.3)
if [ "${master_branch}" != 10.3 ]; then
sudo mysql -e "set password=password('rootpass')"
else
# Even without unix_socket, on some of VMs the password might be not
# pre-created as expected. This command should normally fail.
sudo mysql -uroot -e "set password = password('rootpass')" >/dev/null 2>&1
fi

mysql --verbose -uroot -prootpass -e "create database test; use test; create table t(a int primary key) engine=innodb; insert into t values (1); select * from t; drop table t; drop database test; create user galera identified by 'gal3ra123'; grant all on *.* to galera;"
mysql -uroot -prootpass -e "select @@version"
sudo mariadb --verbose -e "create database test; use test; create table t(a int primary key) engine=innodb; insert into t values (1); select * from t; drop table t; drop database test; create user galera identified by 'gal3ra123'; grant all on *.* to galera;"
sudo mariadb -e "select @@version"
bb_log_info "test for MDEV-18563, MDEV-18526"
set +e

Expand All @@ -118,13 +109,13 @@ control_mariadb_server stop
sleep 1
sudo pkill -9 mysqld
for p in /bin /sbin /usr/bin /usr/sbin /usr/local/bin /usr/local/sbin; do
if test -x $p/mysql_install_db; then
sudo $p/mysql_install_db --no-defaults --user=mysql --plugin-maturity=unknown
if test -x $p/mariadb-install-db; then
sudo $p/mariadb-install-db --no-defaults --user=mysql --plugin-maturity=unknown
else
bb_log_info "$p/mysql_install_db does not exist"
bb_log_info "$p/mariadb-install-db does not exist"
fi
done
sudo mysql_install_db --no-defaults --user=mysql --plugin-maturity=unknown
sudo mariadb-install-db --no-defaults --user=mysql --plugin-maturity=unknown
set +e
## Install mariadb-test for further use
# sudo sh -c "DEBIAN_FRONTEND=noninteractive MYSQLD_STARTUP_TIMEOUT=180 apt-get install -y mariadb-test"
Expand Down
26 changes: 9 additions & 17 deletions scripts/rpm-install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -79,37 +79,29 @@ case "$systemdCapability" in
;;
esac

if [ "${master_branch}" != "10.3" ]; then
bb_log_info "uninstallation of Cracklib plugin may fail if it wasn't installed, it's quite all right"
if sudo mysql -e "uninstall soname 'cracklib_password_check.so'"; then
# shellcheck disable=SC2034
reinstall_cracklib_plugin="YES"
fi
sudo mysql -e "set password=''"
fi
mysql -uroot -e 'drop database if exists test; create database test; use test; create table t(a int primary key) engine=innodb; insert into t values (1); select * from t; drop table t;'
sudo mariadb -e 'drop database if exists test; create database test; use test; create table t(a int primary key) engine=innodb; insert into t values (1); select * from t; drop table t;'
if find rpms/*.rpm | grep -qi columnstore; then
mysql --verbose -uroot -e "create database cs; use cs; create table cs.t_columnstore (a int, b char(8)); insert into cs.t_columnstore select seq, concat('val',seq) from seq_1_to_10; select * from cs.t_columnstore"
sudo mariadb --verbose -e "create database cs; use cs; create table cs.t_columnstore (a int, b char(8)); insert into cs.t_columnstore select seq, concat('val',seq) from seq_1_to_10; select * from cs.t_columnstore"
sudo systemctl restart mariadb
mysql --verbose -uroot -e "select * from cs.t_columnstore; update cs.t_columnstore set b = 'updated'"
sudo mariadb --verbose -e "select * from cs.t_columnstore; update cs.t_columnstore set b = 'updated'"
sudo systemctl restart mariadb-columnstore
mysql --verbose -uroot -e "update cs.t_columnstore set a = a + 10; select * from cs.t_columnstore"
sudo mariadb --verbose -e "update cs.t_columnstore set a = a + 10; select * from cs.t_columnstore"
fi
mysql -uroot -e 'show global status like "wsrep%%"'
sudo mariadb -e 'show global status like "wsrep%%"'
bb_log_info "test for MDEV-18563, MDEV-18526"
set +e
control_mariadb_server stop

sleep 1
sudo pkill -9 mysqld
for p in /bin /sbin /usr/bin /usr/sbin /usr/local/bin /usr/local/sbin; do
if test -x $p/mysql_install_db; then
sudo $p/mysql_install_db --no-defaults --user=mysql --plugin-maturity=unknown
if test -x $p/mariadb-install-db; then
sudo $p/mariadb-install-db --no-defaults --user=mysql --plugin-maturity=unknown
else
bb_log_warn "$p/mysql_install_db does not exist"
bb_log_warn "$p/mariadb-install-db does not exist"
fi
done
sudo mysql_install_db --no-defaults --user=mysql --plugin-maturity=unknown
sudo mariadb-install-db --no-defaults --user=mysql --plugin-maturity=unknown
set +e

bb_log_ok "all done"
7 changes: 4 additions & 3 deletions scripts/rpm-upgrade.sh
Original file line number Diff line number Diff line change
Expand Up @@ -271,14 +271,15 @@ if [[ $test_type == "major" ]]; then
fi

# Make sure that the new server is running
if mysql -uroot -prootpass -e "select @@version" | grep "$old_version"; then
if sudo mariadb -e "select @@version" | grep "$old_version"; then
bb_log_err "the server was not upgraded or was not restarted after upgrade"
exit 1
fi

# Run mysql_upgrade for non-GA branches (minor upgrades in GA branches shouldn't need it)
# Run mariadb-upgrade for non-GA branches (minor upgrades in GA branches
# shouldn't need it)
if [[ $major_version == "$development_branch" ]] || [[ $test_type == "major" ]]; then
sudo -u mysql mysql_upgrade -uroot -prootpass
sudo mariadb-upgrade
fi
set +e

Expand Down

0 comments on commit eaacf38

Please sign in to comment.