NAME

CPAN::Reporter::Smoker - Turnkey CPAN Testers smoking

VERSION

This documentation describes version 0.05.

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

  • 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 downloads and runs programs 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.

CPAN::Mini

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.

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

Skip files

CPAN::Reporter (since 1.08) supports skipfiles to prevent copying authors on reports or from sending reports at all for certain distributions or authors' modules. Use these to stop sending reports if someone complains. See CPAN::Reporter::Config for more details.

A future version may utilize these to avoid testing modules in the skiplist instead of taking the time to test them and then just not send the report.

You may also wish to use CPAN.pm's "distroprefs" to disable testing of certain distributions. See the documentation for CPAN for more details.

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.

$ 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 takes 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() takes one optional argument:

  • restart_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; defaults to 43200 seconds (12 hours)

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 the restart_delay and then continuing

  • PERL_CR_SMOKER_SHORTCUT -- if true, start() will process arguments (if any) but will return before starting smoke testing; used for testing argument handling by start()

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.