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