diff --git a/.fmf/version b/.fmf/version new file mode 100644 index 0000000..d00491f --- /dev/null +++ b/.fmf/version @@ -0,0 +1 @@ +1 diff --git a/gating.yaml b/gating.yaml new file mode 100644 index 0000000..1608530 --- /dev/null +++ b/gating.yaml @@ -0,0 +1,7 @@ +# RHEL +--- !Policy +product_versions: + - rhel-* +decision_context: osci_compose_gate +rules: + - !PassingTestCaseRule {test_case_name: osci.brew-build.tier0.functional} diff --git a/perl-parent.spec b/perl-parent.spec index 52f9867..f47d972 100644 --- a/perl-parent.spec +++ b/perl-parent.spec @@ -1,7 +1,7 @@ Name: perl-parent Epoch: 1 Version: 0.241 -Release: 503%{?dist} +Release: 504%{?dist} Summary: Establish an ISA relationship with base classes at compile time License: GPL-1.0-or-later OR Artistic-1.0-Perl URL: https://metacpan.org/release/parent @@ -13,6 +13,7 @@ BuildRequires: findutils BuildRequires: make BuildRequires: perl-generators BuildRequires: perl-interpreter +BuildRequires: perl(Config) BuildRequires: perl(ExtUtils::MakeMaker) # Module Runtime BuildRequires: perl(strict) @@ -21,6 +22,10 @@ BuildRequires: perl(lib) BuildRequires: perl(Test::More) >= 0.40 # Dependencies +# Remove private test modules +%global __requires_exclude %{?__requires_exclude:%__requires_exclude|}^perl\\(Dummy\\)$ +%global __provides_exclude %{?__provides_exclude:%__provides_exclude|}^perl\\(Dummy|Dummy::(InlineChild|Outside)|ReturnsFalse\\)$ + %description Allows you to both load one or more modules, while setting up inheritance from those modules at the same time. Mostly similar in effect to: @@ -34,8 +39,22 @@ from those modules at the same time. Mostly similar in effect to: push @ISA, qw(Foo Bar); } +%package tests +Summary: Tests for %{name} +Requires: %{name} = %{?epoch:%{epoch}:}%{version}-%{release} +Requires: perl-Test-Harness + +%description tests +Tests from %{name}. Execute them +with "%{_libexecdir}/%{name}/test". + %prep %setup -q -n parent-%{version} +# Help generators to recognize Perl scripts +for F in t/*.t; do + perl -i -MConfig -ple 'print $Config{startperl} if $. == 1 && !s{\A#!.*perl\b}{$Config{startperl}}' "$F" + chmod +x "$F" +done %build perl Makefile.PL INSTALLDIRS=vendor @@ -45,6 +64,14 @@ make %{?_smp_mflags} make pure_install DESTDIR=%{buildroot} find %{buildroot} -type f -name .packlist -delete %{_fixperms} -c %{buildroot} +# Install tests +mkdir -p %{buildroot}%{_libexecdir}/%{name} +cp -a t %{buildroot}%{_libexecdir}/%{name} +cat > %{buildroot}%{_libexecdir}/%{name}/test << 'EOF' +#!/bin/sh +cd %{_libexecdir}/%{name} && exec prove -I . -j "$(getconf _NPROCESSORS_ONLN)" +EOF +chmod +x %{buildroot}%{_libexecdir}/%{name}/test %check make test @@ -54,7 +81,13 @@ make test %{perl_vendorlib}/parent.pm %{_mandir}/man3/parent.3* +%files tests +%{_libexecdir}/%{name} + %changelog +* Fri Jul 12 2024 Michal Josef Špaček - 1:0.241-504 +- Package tests + * Mon Jun 24 2024 Troy Dawson - 1:0.241-503 - Bump release for June 2024 mass rebuild diff --git a/plans/sanity.fmf b/plans/sanity.fmf new file mode 100644 index 0000000..a72ded4 --- /dev/null +++ b/plans/sanity.fmf @@ -0,0 +1,5 @@ +summary: Sanity tests +discover: + how: fmf +execute: + how: tmt diff --git a/tests/upstream-tests.fmf b/tests/upstream-tests.fmf new file mode 100644 index 0000000..b6e02e0 --- /dev/null +++ b/tests/upstream-tests.fmf @@ -0,0 +1,12 @@ +summary: Upstream tests +contact: Michal Josef Spacek +component: perl-parent +require: perl-parent-tests +test: /usr/libexec/perl-parent/test +enabled: true +tag: + - rhel-buildroot +adjust: + - enabled: false + when: distro < rhel-10 or distro < centos-stream-10 + continue: false