Files
perl-Mock-MonkeyPatch/perl-Mock-MonkeyPatch.spec
2025-08-12 18:15:28 +02:00

72 lines
2.4 KiB
RPMSpec

#
# spec file for package perl-Mock-MonkeyPatch
#
# Copyright (c) 2024 SUSE LLC
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
# upon. The license for this file, and modifications and additions to the
# file, is the same license as for the pristine package itself (unless the
# license for the pristine package is not an Open Source License, in which
# case the license is the MIT License). An "Open Source License" is a
# license that conforms to the Open Source Definition (Version 1.9)
# published by the Open Source Initiative.
# Please submit bugfixes or comments via https://bugs.opensuse.org/
#
%define cpan_name Mock-MonkeyPatch
Name: perl-Mock-MonkeyPatch
Version: 1.30.0
Release: 0
# 1.03 -> normalize -> 1.30.0
%define cpan_version 1.03
License: Artistic-1.0 OR GPL-1.0-or-later
Summary: Monkey patching with test mocking in mind
URL: https://metacpan.org/release/%{cpan_name}
Source0: https://cpan.metacpan.org/authors/id/J/JB/JBERGER/%{cpan_name}-%{cpan_version}.tar.gz
Source100: README.md
BuildArch: noarch
BuildRequires: perl
BuildRequires: perl-macros
BuildRequires: perl(Module::Build)
BuildRequires: perl(Module::Build::Tiny) >= 0.039
BuildRequires: perl(Sub::Util) >= 1.40
BuildRequires: perl(Test::More) >= 0.96
Requires: perl(Sub::Util) >= 1.40
Provides: perl(Mock::MonkeyPatch) = %{version}
%undefine __perllib_provides
%{perl_requires}
%description
Mocking is a common tool, especially for testing. By strategically
replacing a subroutine, one can isolate segments (units) of code to test
individually. When this is done it is important to know that the mocked sub
was actually called and with what arguments it was called.
Mock::MonkeyPatch injects a subroutine in the place of an existing one. It
returns an object by which you can revisit the manner in which the mocked
subroutine was called. Further when the object goes out of scope (or when
the restore method is called) the original subroutine is replaced.
%prep
%autosetup -n %{cpan_name}-%{cpan_version}
%build
perl Build.PL --installdirs=vendor
./Build build --flags=%{?_smp_mflags}
%check
./Build test
%install
./Build install --destdir=%{buildroot} --create_packlist=0
%perl_gen_filelist
%files -f %{name}.files
%doc Changes README
%license LICENSE
%changelog