(Touchups. This is the version currently in place.) |
(Redirected page to Archive:PackagingDraft:Perl) |
||
(7 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
#REDIRECT [[Archive:PackagingDraft:Perl]] | |||
= Perl Packaging = | = Perl Packaging = | ||
This document seeks to document the conventions and customs surrounding the proper packaging of perl modules in Fedora. It does not intend to cover all situations, but to codify those practices which have served the Fedora perl community well. | This document seeks to document the conventions and customs surrounding the proper packaging of perl modules in Fedora. It does not intend to cover all situations, but to codify those practices which have served the Fedora perl community well. | ||
{{Anchor|licensetag}} | {{Anchor|licensetag}} | ||
Line 21: | Line 21: | ||
As an example, assume that <code>perl-A-B</code> depends on <code>perl-A</code> and installs files into /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A/B. The base Perl package guarantees that it will own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi for as long as it remains compatible with version 5.10.0, but a future upgrade of the <code>perl-A</code> package may install into (and thus own) /usr/lib/perl5/vendor_perl/5.11.0/i386-linux-thread-multi/A. So the <code>perl-A-B</code> package needs to own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A as well as /usr/lib/perl5/vendor_perl/5.8.8/i386-linux-thread-multi/A/B in order to maintain proper ownership. | As an example, assume that <code>perl-A-B</code> depends on <code>perl-A</code> and installs files into /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A/B. The base Perl package guarantees that it will own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi for as long as it remains compatible with version 5.10.0, but a future upgrade of the <code>perl-A</code> package may install into (and thus own) /usr/lib/perl5/vendor_perl/5.11.0/i386-linux-thread-multi/A. So the <code>perl-A-B</code> package needs to own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A as well as /usr/lib/perl5/vendor_perl/5.8.8/i386-linux-thread-multi/A/B in order to maintain proper ownership. | ||
'''Put more simply:''' | |||
''A noarch package must own:'' | |||
<pre> | |||
%{perl_vendorlib}/* | |||
</pre> | |||
''A arch-specific package must own:'' | |||
<pre> | |||
%{perl_vendorarch}/* | |||
%exclude %dir %{perl_vendorarch}/auto/ | |||
</pre> | |||
{{Anchor|requiresandprovides}} | {{Anchor|requiresandprovides}} | ||
Line 27: | Line 42: | ||
Perl packages use the virtual <code>perl(Foo)</code> naming to indicate a given perl module. Packages should use this methodology, and not require the package name directly. E.g. a package requires the perl module Readonly, a package should not explicitly require the package <code>perl-Readonly</code>, but rather <code>perl(Readonly)</code>, which the <code>perl-Readonly</code> package provides. | Perl packages use the virtual <code>perl(Foo)</code> naming to indicate a given perl module. Packages should use this methodology, and not require the package name directly. E.g. a package requires the perl module Readonly, a package should not explicitly require the package <code>perl-Readonly</code>, but rather <code>perl(Readonly)</code>, which the <code>perl-Readonly</code> package provides. | ||
{{ | {{admon/caution|Do not buildrequires perl-devel|Explicitly requiring <code>perl-devel</code>, even when wrapped in a conditional construct, is strongly discouraged, and is generally considered a blocker at review and a packaging bug. Instead, see the next section on requiring core modules -- making sure that these core modules are BR'ed when used will pull in the correct development perl packages.}} | ||
Line 33: | Line 49: | ||
== Core modules as buildrequires == | == Core modules as buildrequires == | ||
Historically, buildrequiring a core module (that is, one provided by the perl package itself) has been frowned upon. However, with the perl/perl-devel split, a number of core modules are now packages seperately from the perl package, and now need to be explicitly buildrequired | Historically, buildrequiring a core module (that is, one provided by the perl package itself) has been frowned upon. However, with the perl/perl-devel split, a number of core modules are now packages seperately from the perl package, and now need to be explicitly buildrequired. | ||
{{Anchor|module_compat}} | {{Anchor|module_compat}} | ||
Line 60: | Line 69: | ||
== Filtering Requires: and Provides == | == Filtering Requires: and Provides == | ||
RPM's dependency generator can often throw in additional dependencies and will often think packages provide functionality contrary to reality. To fix this, the dependency generator needs to be overriden so that the additional dependencies can be filtered out. | RPM's dependency generator can often throw in additional dependencies and will often think packages provide functionality contrary to reality. To fix this, the dependency generator needs to be overriden so that the additional dependencies can be filtered out. | ||
For more information on the auto-requires/provides filtering framework, please see '''FIXME'''. | |||
=== Perl standard filtering === | |||
All perl-* packages should include this, before %description: | |||
<pre> | <pre> | ||
%{?perl_default_filter} | |||
</pre> | </pre> | ||
=== | === Explicit filtering === | ||
'''FIXME'''' | |||
{{Anchor|manualdeps}} | {{Anchor|manualdeps}} | ||
Line 182: | Line 157: | ||
With this construct, an offending test will be removed and not executed, unless "--with network_tests" is passed to <code>rpmbuild</code> or %_with_network_tests is defined somewhere, e.g. in a user's <code>$HOME/.rpmmacros</code>. This approach preserves the test suite for local builds while working within the technical limitations of the buildsystem. | With this construct, an offending test will be removed and not executed, unless "--with network_tests" is passed to <code>rpmbuild</code> or %_with_network_tests is defined somewhere, e.g. in a user's <code>$HOME/.rpmmacros</code>. This approach preserves the test suite for local builds while working within the technical limitations of the buildsystem. | ||
= | = App::* namespace packages = | ||
{{admon/warning|Stub!|This is a stub section, please flesh it out!}} | |||
Essentially: When packaging an App::* namespace package, generally these are focused on delivering some sort of executable script, which should be in its own sub-package because... | |||
* | |||
= Helper RPM macros = | |||
{{admon/warning|Stub!|This is a stub section, please flesh it out!}} | |||
= .h files in module packages = | = .h files in module packages = | ||
It is not uncommon for binary module packages to include .h files, see e.g. <code>perl-DBI</code>, <code>perl-Glib</code>, <code>perl-Gtk2</code>. For a variety of reasons these | It is not uncommon for binary module packages to include .h files, see e.g. <code>perl-DBI</code>, <code>perl-Glib</code>, <code>perl-Gtk2</code>. For a variety of reasons these must not be split off into a -devel package. | ||
= Set inital-cc to 'perl-sig' = | = Set inital-cc to 'perl-sig' = | ||
Line 202: | Line 176: | ||
= cpanspec = | = cpanspec = | ||
/!\ FIXME -- this should be genericised and revised; there's a number of CPAN-to-RPM spec generation tools now, some Fedora-specific. | |||
<code>cpanspec</code> is an excellent little tool to assist in creating Fedora-compliant packages from CPAN-based modules. Its use as a starting point is recommended (but certainly not mandated). | <code>cpanspec</code> is an excellent little tool to assist in creating Fedora-compliant packages from CPAN-based modules. Its use as a starting point is recommended (but certainly not mandated). |
Latest revision as of 00:50, 19 February 2016
Redirect to:
Perl Packaging
This document seeks to document the conventions and customs surrounding the proper packaging of perl modules in Fedora. It does not intend to cover all situations, but to codify those practices which have served the Fedora perl community well.
License tag
Perl itself is dual licensed, under both the GPL and Artistic licenses. Many perl modules follow this practice; when they do, the license tag should be filled out as "GPL+ or Artistic", not the other way around.
Note also that under the new license tag guidelines , it's important to specify "GPL+" not just "GPL" for those packages "licensed under the same terms as perl itself."
License: GPL+ or Artistic
Directory Ownership
As specified in the general Packaging Guidelines , perl packages are permitted to share ownership of directories.
As an example, assume that perl-A-B
depends on perl-A
and installs files into /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A/B. The base Perl package guarantees that it will own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi for as long as it remains compatible with version 5.10.0, but a future upgrade of the perl-A
package may install into (and thus own) /usr/lib/perl5/vendor_perl/5.11.0/i386-linux-thread-multi/A. So the perl-A-B
package needs to own /usr/lib/perl5/vendor_perl/5.10.0/i386-linux-thread-multi/A as well as /usr/lib/perl5/vendor_perl/5.8.8/i386-linux-thread-multi/A/B in order to maintain proper ownership.
Put more simply:
A noarch package must own:
%{perl_vendorlib}/*
A arch-specific package must own:
%{perl_vendorarch}/* %exclude %dir %{perl_vendorarch}/auto/
Perl Requires and Provides
Perl packages use the virtual perl(Foo)
naming to indicate a given perl module. Packages should use this methodology, and not require the package name directly. E.g. a package requires the perl module Readonly, a package should not explicitly require the package perl-Readonly
, but rather perl(Readonly)
, which the perl-Readonly
package provides.
Core modules as buildrequires
Historically, buildrequiring a core module (that is, one provided by the perl package itself) has been frowned upon. However, with the perl/perl-devel split, a number of core modules are now packages seperately from the perl package, and now need to be explicitly buildrequired.
Versioned MODULE_COMPAT_ Requires
All perl modules must include the versioned MODULE_COMPAT Requires:
Requires: perl(:MODULE_COMPAT_%(eval "`%{__perl} -V:version`"; echo $version))
This is to ensure that perl packages have a dependency on a perl which provides the appropriate versioned directory structure (otherwise, the modules won't be found).
Packages that link to libperl
Some packages link to libperl.so, usually to provide embedded perl functionality. All of these packages must also use the versioned MODULE_COMPAT Requires.
Filtering Requires: and Provides
RPM's dependency generator can often throw in additional dependencies and will often think packages provide functionality contrary to reality. To fix this, the dependency generator needs to be overriden so that the additional dependencies can be filtered out.
For more information on the auto-requires/provides filtering framework, please see FIXME.
Perl standard filtering
All perl-* packages should include this, before %description:
%{?perl_default_filter}
Explicit filtering
FIXME'
Manual Requires and Provides
Under some circumstances, RPM's automatic dependency generator can miss dependencies that should be added.
This is usually as a result of using language constructs that the dependency script wasn't expecting.
An example of this is in the perl-Class-Accessor-Chained
package, where the following can be found:
use base 'Class::Accessor::Fast'; ... use base 'Class::Accessor';
A tell-tale sign of this particular construct is that the package contains a dependency on perl(base)
, but this is not the only situation in which dependencies can be missed. This package needed additional dependencies as follows:
Requires: perl(Class::Accessor), perl(Class::Accessor::Fast)
In general, it's a good idea to look at the upstream package's documentation for details of other dependencies.
Another similar example of missing requirements can be seen in perl-Spreadsheet-WriteExcel
:
package Spreadsheet::WriteExcel::Utility; ... use autouse 'Date::Calc' => qw(Delta_DHMS Decode_Date_EU Decode_Date_US); use autouse 'Date::Manip' => qw(ParseDate Date_Init);
Similarly, it possible to miss Provides:, as was the case in Bug #167797 , where the perl-DBD-Pg
package failed to Provide: perl(DBD::Pg)
due to the following construct in DBD::Pg
version 1.43:
{ package DBD::Pg;
The usual way of writing this, and what's expected by RPM, is:
{ package DBD::Pg;
So it's wise to examine the Provides: of your packages to check that they are sane and complete. If something is missing, it can be fixed either by using manual Provides: entries, or by patching the source to use a format that RPM can parse correctly.
URL tag
For CPAN-based packages the URL tag should use a non-versioned search.cpan.org URL. E.g., if one were packaging the module Net::XMPP, the URL would be:
URL: http://search.cpan.org/dist/Net-XMPP/
Testing and Test Suites
Perl packages typically have a large, healthy test suite. It is policy to run as much of the test suite as possible, subject to the technical limitations of the buildsystem. This means, at the least:
- All modules required for tests should be listed as a buildrequires
- Any "optional" tests should be enabled
- Any modules needed for the tests but not yet in Fedora that could be included in Fedora should also be submitted for review
When to *not* test
There are a couple caveats here:
- Optional tests do not need to be enabled if they will cause circular build deps
- Tests which require network or display access should be disabled for the buildsystem, but with a method provided for local builds
- Tests which do not test package functionality should still be invoked, but their exclusion not be considered a blocker (e.g. Test::Pod::Coverage, Test::Kwalitee and the like)
Additionally, for "meta" packages that provide a common interface to a number of similar modules, it is not necessary to package all of the modules that the package supports so long as at least one module exists to allow the meta package to provide functionality. For instance, the package perl-JSON-Any (JSON::Any) provides a common interface to JSON, JSON::XS, JSON::PC, JSON::Syck and JSON::DWIM; JSON::PC and JSON::DWIM are not currently in Fedora and do not need to be packaged.
Conditionally enabling/disabling tests
One common way to disable a test for mock but enable it locally is to use a _with_foo
macro test. e.g.:
%check %{?!_with_network_tests: rm t/roster.t } ./Build test
With this construct, an offending test will be removed and not executed, unless "--with network_tests" is passed to rpmbuild
or %_with_network_tests is defined somewhere, e.g. in a user's $HOME/.rpmmacros
. This approach preserves the test suite for local builds while working within the technical limitations of the buildsystem.
App::* namespace packages
Essentially: When packaging an App::* namespace package, generally these are focused on delivering some sort of executable script, which should be in its own sub-package because...
Helper RPM macros
.h files in module packages
It is not uncommon for binary module packages to include .h files, see e.g. perl-DBI
, perl-Glib
, perl-Gtk2
. For a variety of reasons these must not be split off into a -devel package.
Set inital-cc to 'perl-sig'
It's common practice to set the Fedora perl SIG mailing list as a member of the initial-cc list for bugzilla. This can be done by adding the user perl-sig
to the initial CC list.
cpanspec
/!\ FIXME -- this should be genericised and revised; there's a number of CPAN-to-RPM spec generation tools now, some Fedora-specific.
cpanspec
is an excellent little tool to assist in creating Fedora-compliant packages from CPAN-based modules. Its use as a starting point is recommended (but certainly not mandated).
For more information, see: Perl/cpanspec