NAME
CPAN::Reporter::Smoker - Turnkey CPAN Testers smoking
VERSION
This documentation describes version 0.10.
SYNOPSIS
$ perl -MCPAN::Reporter::Smoker -e start
DESCRIPTION
Rudimentary smoke tester for CPAN Testers, built upon CPAN::Reporter. Use at your own risk. It requires a recent version of CPAN::Reporter to run.
Currently, CPAN::Reporter::Smoker requires zero independent configuration; instead it uses configuration settings from CPAN.pm and CPAN::Reporter.
Once started, it retrieves a list of distributions from the configured CPAN mirror and begins testing them in reverse order of upload. It will skip any distribution which has already had a report sent by CPAN::Reporter.
Features (or bugs, depending on your point of view):
No configuration needed
Tests each distribution as a separate CPAN process -- each distribution has prerequisites like build_requires satisfied from scratch
Automatically checks for new distributions every twelve hours or as otherwise specified
Continues until interrupted with CTRL-C
Current limitations:
Does not check any skip files before handing off to CPAN to test -- use CPAN.pm "distroprefs" instead
Does not attempt to retest distributions that had reports discarded because of prerequisites that could not be satisfied
WARNING -- smoke testing is risky
Smoke testing will download and run programs that other people have uploaded to CPAN. These programs could do anything to your system, including deleting everything on it. Do not run CPAN::Reporter::Smoker unless you are prepared to take these risks.
HINTS
Selection of distributions to test
Only the most recently uploaded developer and normal releases will be tested, and only if the developer release is newer than the regular release indexed by PAUSE.
For example, if Foo-Bar-0.01, Foo-Bar-0.02, Foo-Bar-0.03_01 and Foo-Bar-0.03_02 are on CPAN, only Foo-Bar-0.02 and Foo-Bar-0.03_02 will be tested, and in reverse order of when they were uploaded. Once Foo-Bar-0.04 is released and indexed, Foo-Bar-0.03_02 will not longer be tested.
To avoid testing script or other tarballs, developer distributions included must have a base distribution name that resembles a distribution tarball already indexed by PAUSE. If the first upload of distribution to PAUSE is a developer release -- Baz-Bam-0.00_01.tar.gz -- it will not be tested as there is no indexed Baz-Bam appearing in CPAN's 02packages.details.txt file.
Unauthorized tarballs are treated like developer releases and will be tested if they resemble an indexed distribution and are newer than the indexed tarball.
Perl, parrot, kurila, Pugs and similar distributions will not be tested. The skip list is based on CPAN::Mini and matches as follows:
qr{(?:
/(?:emb|syb|bio)?perl-\d
| /(?:parrot|ponie|kurila|Perl6-Pugs)-\d
| /perl-?5\.004
| /perl_mlb\.zip
)}xi,
Bundles and mod_perl distributions will also not be tested, though mod_perl is likely to be requested as a dependency by many modules. See the next section for how to tell CPAN.pm not to test certain dependencies.
Skipping additional distributions
If certain distributions hang, crash or otherwise cause trouble, you can use CPAN's "distroprefs" system to disable them. If a distribution is disabled, it won't be built or tested. If a distribution's dependency is disabled, a failing test is just discarded.
The first step is configuring a directory for distroprefs files:
$ cpan
cpan> o conf init prefs_dir
cpan> o conf commit
Next, ensure that either the YAML or YAML::Syck module is installed. (YAML::Syck is faster). Then create a file in the prefs_dir
directory to hold the list of distributions to disable, e.g. call it disabled.yml
In that file, you can add blocks of YAML code to disable distributions. The match criteria "distribution" is a regex that matches against the canonical name of a distribution, e.g. AUTHOR/Foo-Bar-3.14.tar.gz
.
Here is a sample file to show you some syntax (don't actually use these, though):
---
comment: "Tests take too long"
match:
distribution: "^DAGOLDEN/CPAN-Reporter-\d"
disabled: 1
---
comment: "Skip Win32 distributions"
match:
distribution: "/Win32"
disabled: 1
---
comment: "Skip distributions by Andy Lester"
match:
distribution: "^PETDANCE"
disabled: 1
Please note that disabling distributions like this will also disable them for normal, non-smoke usage of CPAN.pm.
One distribution that I would recommend either installing up front or else disabling with distroprefs is mod_perl, as it is a common requirement for many Apache:: modules but does not (easily) build and test under automation.
---
comment: "Don't build mod_perl if required by some other module"
match:
distribution: "/mod_perl-\d"
disabled: 1
Distroprefs are more powerful than this -- they can be used to automate responses to prompts in distributions, set environment variables, specify additional dependencies and so on. Read the docs for CPAN.pm for more and look in the "distroprefs" directory in the CPAN distribution tarball for examples.
Turning off reports to authors
CPAN::Reporter (since 1.08) supports skipfiles to avoid copying certain authors on failing reports or to prevent sending a report at all to CPAN Testers. Use these to stop sending reports if someone complains. See CPAN::Reporter::Config for more details.
Note -- these do not stop CPAN::Reporter::Smoker from processing distributions. They only change whether reports are sent and to whom.
If you don't want to copy authors at all, set the "cc_author" option to "no" in your CPAN::Reporter config file.
cc_author = no
Using a local CPAN::Mini mirror
Because distributions must be retrieved from a CPAN mirror, the smoker may cause heavy network load and will reptitively download common build prerequisites.
An alternative is to use CPAN::Mini to create a local CPAN mirror and to point CPAN's urllist
to the local mirror.
$ cpan
cpan> o conf urllist unshift file:///path/to/minicpan
cpan> o conf commit
However, CPAN::Reporter::Smoker needs the find-ls.gz
file, which CPAN::Mini does not mirror by default. Add it to a .minicpanrc file in your home directory to include it in your local CPAN mirror.
also_mirror: indices/find-ls.gz
Note that CPAN::Mini does not mirror developer versions. Therefore, a live, network CPAN Mirror will be needed in the urllist to retrieve these.
Note that CPAN requires the LWP module to be installed to use a local CPAN mirror.
Alternatively, you might experiment with the alpha-quality release of CPAN::Mini::Devel, which subclasses CPAN::Mini to retrieve developer distributions (and find-ls.gz) using the same logic as CPAN::Reporter::Smoker.
Timing out hanging tests
CPAN::Reporter (since 1.08) supports a 'command_timeout' configuration option. Set this option in the CPAN::Reporter configuration file to time out tests that hang up or get stuck at a prompt. Set it to a high-value to avoid timing out a lengthy tests that are still running -- 1000 or more seconds is probably enough.
Warning -- on Win32, terminating processes via the command_timeout is equivalent to SIGKILL and could cause system instability or later deadlocks
This option is still considered experimental.
Avoiding repetitive prerequisite testing
Because CPAN::Reporter::Smoker satisfies all requirements from scratch, common dependencies (e.g. Class::Accessor) will be unpacked, built and tested repeatedly.
As of version 1.92_56, CPAN supports the trust_test_report_history
config option. When set, CPAN will check the last test report for a distribution. If one is found, the results of that test are used instead of running tests again.
$ cpan
cpan> o conf init trust_test_report_history
cpan> o conf commit
Avoiding repetitive prerequisite builds
CPAN has a build_dir_reuse
config option. When set (and if a YAML module is installed and configured), CPAN will attempt to make build directories persistent. This has the unfortunate side-effect of ballooning PERL5LIB
with all build directories that ever passed their tests. When smoke testing, this is potentially fatal if the maximum environment variable is exceeded.
However, as of version 1.92_59, CPAN has a function to reset the list of directories to be included in PERL5LIB
. If this function is available, CPAN::Reporter::Smoker will reset the list prior to testing each distribution.
Also, CPAN version 1.92_58 changed to use an external YAML file to load large numbers of prerequisite directories instead of relying on PERL5LIB
. While slightly buggy when first introduced, it has stablized around 1.92_61.
Taken together, build_dir_reuse
now has the potential to save substantial time and space during smoke testing, but please make sure to use the latest version of CPAN to avoid major problems.
$ cpan
cpan> o conf init build_dir_reuse
cpan> o conf commit
Stopping early if a prerequisite fails
Normally, CPAN.pm continues testing a distribution even if a prequisite fails to build or fails testing. Some distributions may pass their tests even without a listed prerequisite, but most just fail (and CPAN::Reporter discards failures if prerequisites are not met).
As of version 1.92_57, CPAN supports the halt_on_failure
config option. When set, a prerequisite failure stops further processing.
$ cpan
cpan> o conf init halt_on_failure
cpan> o conf commit
However, a disadvantage of halting early is that no DISCARD grade is recorded in the history. The next time CPAN::Reporter::Smoker runs, the distribution will be tested again from scratch. It may be better to let all prerequisites finish so the distribution can fail its test and be flagged with DISCARD so it will be skipped in the future.
CPAN cache bloat
CPAN will use a lot of scratch space to download, build and test modules. Use CPAN's built-in cache management configuration to let it purge the cache periodically if you don't want to do this manually. When configured, the cache will be purged on start and after a certain number of distributions have been tested as determined by the clean_cache_after
option for the start()
function.
$ cpan
cpan> o conf init build_cache scan_cache
cpan> o conf commit
CPAN verbosity
Recent versions of CPAN are verbose by default, but include some lesser known configuration settings to minimize this for untarring distributions and for loading support modules. Setting the verbosity for these to 'none' will minimize some of the clutter to the screen as distributions are tested.
$ cpan
cpan> o conf init /verbosity/
cpan> o conf commit
Test::Reporter timeouts and MAILDOMAIN
On some systems (e.g. Win32), Test::Reporter may take a long time to determine the origin domain for mail. Set the MAILDOMAIN environment variable instead to avoid this delay.
USAGE
start()
Starts smoke testing using defaults already in CPAN::Config and CPAN::Reporter's .cpanreporter directory. Runs until all distributions are tested or the process is halted with CTRL-C or otherwise killed.
start()
supports several optional arguments:
clean_cache_after
-- number of distributions that will be tested before checking to see if the CPAN build cache needs to be cleaned up (not including any prerequisites tested); must be a positive integer; defaults to 100restart_delay
-- number of seconds that must elapse before restarting smoke testing; this will reload indices to search for new distributions and restart testing from the most recent distribution; must be a positive integer; defaults to 43200 seconds (12 hours)set_term_title
-- toggle for whether the terminal titlebar will be updated with the distribution being smoke tested and the starting time of the test; helps determine if a test is hung and which distribution might be responsible; valid values are 0 or 1; defaults to 1
ENVIRONMENT
Automatically sets the following environment variables to true values while running:
AUTOMATED_TESTING
-- signal that tests are being run by an automated smoke testing program (i.e. don't expect interactivity)PERL_MM_USE_DEFAULT
-- accept ExtUtils::MakeMaker prompt() defaults
The following environment variables, if set, will modify the behavior of CPAN::Reporter::Smoker. Generally, they are only required during the testing of CPAN::Reporter::Smoker
PERL_CR_SMOKER_RUNONCE
-- if true,start()
will exit after all distributions are tested instead of sleeping for therestart_delay
and then continuingPERL_CR_SMOKER_SHORTCUT
-- if true,start()
will process arguments (if any) but will return before starting smoke testing; used for testing argument handling bystart()
BUGS
Please report any bugs or feature using the CPAN Request Tracker. Bugs can be submitted through the web interface at http://rt.cpan.org/Dist/Display.html?Queue=CPAN-Reporter-Smoker
When submitting a bug or request, please include a test-file or a patch to an existing test-file that illustrates the bug or desired feature.
SEE ALSO
AUTHOR
David A. Golden (DAGOLDEN)
COPYRIGHT AND LICENSE
Copyright (c) 2008 by David A. Golden
Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0
Files produced as output though the use of this software, shall not be considered Derivative Works, but shall be considered the original work of the Licensor.
Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.