Enable tests

This commit is contained in:
Jitka Plesnikova 2019-06-26 09:34:04 +02:00
parent 8d05433121
commit 87efa815cc
3 changed files with 82 additions and 19 deletions

View File

@ -1,10 +1,12 @@
Name: perl-DBD-MariaDB
Version: 1.21
Release: 1%{?dist}
Release: 2%{?dist}
Summary: MariaDB and MySQL driver for the Perl5 Database Interface (DBI)
License: GPL+ or Artistic
URL: https://metacpan.org/release/DBD-MariaDB/
Source0: https://cpan.metacpan.org/authors/id/P/PA/PALI/DBD-MariaDB-%{version}.tar.gz
Source1: test-setup
Source2: test-clean
BuildRequires: findutils
BuildRequires: gcc
BuildRequires: make
@ -27,22 +29,25 @@ BuildRequires: perl(Getopt::Long)
BuildRequires: perl(strict)
BuildRequires: perl(utf8)
BuildRequires: perl(warnings)
# Tests - not run
#BuildRequires: perl(B)
#BuildRequires: perl(bigint)
#BuildRequires: perl(constant)
#BuildRequires: perl(DBI::Const::GetInfoType)
#BuildRequires: perl(Encode)
#BuildRequires: perl(File::Temp)
#BuildRequires: perl(FindBin)
#BuildRequires: perl(lib)
#BuildRequires: perl(Net::SSLeay)
#BuildRequires: perl(Proc::ProcessTable)
#BuildRequires: perl(Storable)
#BuildRequires: perl(Test::Deep)
#BuildRequires: perl(Test::More) >= 0.90
#BuildRequires: perl(Time::HiRes)
#BuildRequires: perl(vars)
# Tests
BuildRequires: mariadb
BuildRequires: mariadb-server
BuildRequires: perl(B)
BuildRequires: perl(bigint)
BuildRequires: perl(constant)
BuildRequires: perl(DBI::Const::GetInfoType)
BuildRequires: perl(Encode)
BuildRequires: perl(File::Temp)
BuildRequires: perl(FindBin)
BuildRequires: perl(lib)
BuildRequires: perl(Net::SSLeay)
BuildRequires: perl(Proc::ProcessTable)
BuildRequires: perl(Storable)
BuildRequires: perl(Test::Deep)
BuildRequires: perl(Test::More) >= 0.90
BuildRequires: perl(Time::HiRes)
BuildRequires: perl(vars)
Requires: perl(:MODULE_COMPAT_%(eval "`perl -V:version`"; echo $version))
%description
@ -66,8 +71,13 @@ find $RPM_BUILD_ROOT -type f -name '*.bs' -size 0 -delete
%{_fixperms} $RPM_BUILD_ROOT/*
%check
# Full test coverage requires a live MariaDB database
#make test
# Setup environment and start database
. %{SOURCE1}
make test
# Stop database
. %{SOURCE2}
%files
%license LICENSE
@ -77,5 +87,8 @@ find $RPM_BUILD_ROOT -type f -name '*.bs' -size 0 -delete
%{_mandir}/man3/*
%changelog
* Wed Jun 26 2019 Jitka Plesnikova <jplesnik@redhat.com> - 1.21-2
- Enable tests
* Thu Jun 13 2019 Jitka Plesnikova <jplesnik@redhat.com> - 1.21-1
- Specfile autogenerated by cpanspec 1.78.

6
test-clean Executable file
View File

@ -0,0 +1,6 @@
#!/bin/bash
/usr/bin/mysqladmin --user=root --socket=${MYSQL_UNIX_PORT} shutdown 2>&1 || \
[ ! -s "${MYSQL_PIDFILE}" ] || /bin/kill `cat "${MYSQL_PIDFILE}"` || true
rm -rf ${MYSQL_DIR}

44
test-setup Executable file
View File

@ -0,0 +1,44 @@
#!/bin/bash
# MySQL setup
export MYSQL_DIR=$PWD/t/testdb
export MYSQL_UNIX_PORT=$MYSQL_DIR/mysql.sock
export MYSQL_PIDFILE=$MYSQL_DIR/mysql.pid
export MYSQL_USER=`whoami`
# DBD::MariaDB test setup
export DBD_MARIADB_TESTDB=testdb
export DBD_MARIADB_TESTHOST=localhost
export DBD_MARIADB_TESTSOCKET=$MYSQL_UNIX_PORT
export DBD_MARIADB_TESTUSER=testuser
export DBD_MARIADB_TESTPASSWORD=testpassword
if mysql --version | grep -q MariaDB; then
mysql_install_db --no-defaults --datadir=${MYSQL_DIR} --force --skip-name-resolve --explicit_defaults_for_timestamp --user=${MYSQL_USER} 2>&1
#mysqld_safe --no-defaults --user=${MYSQL_USER} --socket=${MYSQL_UNIX_PORT} --datadir=${MYSQL_DIR} --pid-file=${MYSQL_PIDFILE} 2>&1 &
MYSQLD=/usr/libexec/mysqld
else
MYSQLD=/usr/sbin/mysqld
$MYSQLD --no-defaults --initialize-insecure --datadir=${MYSQL_DIR} --explicit_defaults_for_timestamp --user=${MYSQL_USER} 2>&1
fi
$MYSQLD --no-defaults --user=${MYSQL_USER} --socket=${MYSQL_UNIX_PORT} --datadir=${MYSQL_DIR} --pid-file=${MYSQL_PIDFILE} --explicit_defaults_for_timestamp --skip-networking 2>&1 &
attempts=0
while ! /usr/bin/mysqladmin --user=root --socket=${MYSQL_UNIX_PORT} ping 2>&1 ; do
sleep 3
attempts=$((attempts+1))
if [ ${attempts} -gt 10 ] ; then
echo "skipping test, mariadb/mysql server could not be contacted after 30 seconds"
exit 1
fi
done
mysql --user=root --socket=${MYSQL_UNIX_PORT} --execute "CREATE USER '${DBD_MARIADB_TESTUSER}'@'localhost';" 2>&1
mysql --user=root --socket=${MYSQL_UNIX_PORT} --execute "CREATE DATABASE IF NOT EXISTS ${DBD_MARIADB_TESTDB} CHARACTER SET='utf8mb4';" 2>&1
mysql --user=root --socket=${MYSQL_UNIX_PORT} --execute "GRANT ALL PRIVILEGES ON ${DBD_MARIADB_TESTDB}.* TO '${DBD_MARIADB_TESTUSER}'@'localhost' IDENTIFIED BY '${DBD_MARIADB_TESTPASSWORD}';" 2>&1
if ! /usr/bin/mysqladmin --user=${DBD_MARIADB_TESTUSER} --password=${DBD_MARIADB_TESTPASSWORD} --socket=${DBD_MARIADB_TESTSOCKET} ping 2>&1; then
echo "skipping test, cannot connect to server with test user"
exit 1
fi