From c45906cf8c1ed9a1257bd689d3bfc233cd5b2798 Mon Sep 17 00:00:00 2001 From: Jitka Plesnikova Date: Mon, 20 Nov 2023 17:08:44 +0100 Subject: [PATCH] Package tests --- .fmf/version | 1 + gating.yaml | 16 +++++++++++++++ perl-Module-Load.spec | 42 ++++++++++++++++++++++++++++++++++++---- plans/sanity.fmf | 5 +++++ tests/upstream-tests.fmf | 4 ++++ 5 files changed, 64 insertions(+), 4 deletions(-) create mode 100644 .fmf/version create mode 100644 gating.yaml create mode 100644 plans/sanity.fmf create mode 100644 tests/upstream-tests.fmf 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..3b56a2d --- /dev/null +++ b/gating.yaml @@ -0,0 +1,16 @@ +--- !Policy +product_versions: + - fedora-* +decision_context: bodhi_update_push_testing +subject_type: koji_build +rules: + - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build.tier0.functional} + +# Rawhide +--- !Policy +product_versions: + - fedora-* +decision_context: bodhi_update_push_stable +subject_type: koji_build +rules: + - !PassingTestCaseRule {test_case_name: fedora-ci.koji-build.tier0.functional} diff --git a/perl-Module-Load.spec b/perl-Module-Load.spec index 83d5975..0393a0f 100644 --- a/perl-Module-Load.spec +++ b/perl-Module-Load.spec @@ -2,7 +2,7 @@ Name: perl-Module-Load # Epoch to compete with perl.spec Epoch: 1 Version: 0.36 -Release: 500%{?dist} +Release: 501%{?dist} Summary: Run-time require of both modules and files License: GPL-1.0-or-later OR Artistic-1.0-Perl URL: https://metacpan.org/release/Module-Load @@ -12,19 +12,22 @@ BuildRequires: coreutils BuildRequires: make BuildRequires: perl-generators BuildRequires: perl-interpreter +BuildRequires: perl(Config) BuildRequires: perl(ExtUtils::MakeMaker) >= 6.76 BuildRequires: perl(strict) # Run-time: BuildRequires: perl(File::Spec) BuildRequires: perl(warnings) # Tests: -BuildRequires: perl(Config) BuildRequires: perl(Data::Dumper) BuildRequires: perl(Exporter) BuildRequires: perl(lib) BuildRequires: perl(Test::More) >= 0.94 BuildRequires: perl(vars) +# Filter modules bundled for tests +%global __provides_exclude_from %{?__provides_exclude_from:%__provides_exclude_from|}^%{_libexecdir} + %description If you consult "perldoc -f require" you will see that "require" will behave differently when given a bare-word or a string. In the case of a string, @@ -37,8 +40,23 @@ notation fitting the particular platform you are on. "load" eliminates the need for this overhead and will just DWYM. +%package tests +Summary: Tests for %{name} +Requires: %{name} = %{?epoch:%{epoch}:}%{version}-%{release} +Requires: perl-Test-Harness +Requires: perl(Data::Dumper) + +%description tests +Tests from %{name}. Execute them +with "%{_libexecdir}/%{name}/test". + %prep %setup -q -n Module-Load-%{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 NO_PACKLIST=1 NO_PERLLOCAL=1 @@ -48,16 +66,32 @@ perl Makefile.PL INSTALLDIRS=vendor NO_PACKLIST=1 NO_PERLLOCAL=1 %{make_install} %{_fixperms} '%{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 +export HARNESS_OPTIONS=j$(perl -e 'if ($ARGV[0] =~ /.*-j([0-9][0-9]*).*/) {print $1} else {print 1}' -- '%{?_smp_mflags}') unset PERL_CORE make test %files %doc CHANGES README -%{perl_vendorlib}/* -%{_mandir}/man3/* +%{perl_vendorlib}/Module* +%{_mandir}/man3/Module::Load* + +%files tests +%{_libexecdir}/%{name} %changelog +* Mon Nov 20 2023 Jitka Plesnikova - 1:0.36-501 +- Package tests + * Thu Jul 20 2023 Fedora Release Engineering - 1:0.36-500 - Rebuilt for https://fedoraproject.org/wiki/Fedora_39_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..f7a240a --- /dev/null +++ b/tests/upstream-tests.fmf @@ -0,0 +1,4 @@ +summary: Upstream tests +component: perl-Module-Load +require: perl-Module-Load-tests +test: /usr/libexec/perl-Module-Load/test