The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
NAME
    App::sync_cpantesters - Sync CPAN testers failure reports to local
    directories

VERSION
    version 1.111470

SYNOPSIS
        $ sync_cpantesters -a MARCEL -d ~/dev/cpan-testers

DESCRIPTION
    CPAN testers provide a valuable service. The reports are available on
    the Web - for example, for CPAN ID "MARCEL", the reports are at
    <http://cpantesters.perl.org/author/MARCEL.html>. I don't like to read
    them in the browser and click on each individual failure report. I also
    don't look at the success reports. I'd rather download the failure
    reports and read them in my favorite editor, vim. I want to be able to
    run this program repeatedly and only download new failure reports, as
    well as delete old ones that no longer appear in the master list -
    probably because a new version of the distribution in question was
    uploaded.

    If you are in the same position, then this program might be for you.

    You need to pass a base directory using the "--dir" options. For each
    distribution for which there are failure reports, a directory is
    created. Each failure report is stored in a file within that
    subdirectory. The HTML is converted to plain text. For example, at one
    point in time, I ran the program using:

        sync_cpantesters -a MARCEL -d reports

    and the directory structure created looked like this:

        reports/Aspect-0.12/449224
        reports/Attribute-Memoize-0.01/39824
        reports/Attribute-Memoize-0.01/71010
        reports/Attribute-Overload-0.04/700557
        reports/Attribute-TieClasses-0.03/700575
        reports/Attribute-Util-1.02/455076
        reports/Attribute-Util-1.02/475237
        reports/Attribute-Util-1.02/477578
        reports/Attribute-Util-1.02/485231
        reports/Attribute-Util-1.02/489218
        ...

METHODS
  author
    The CPAN ID for which you want to download CPAN testers results. In my
    case, this id is "MARCEL".

    You have to use exactly one of "author()" or "uri()".

  uri
    The URI from which to download the CPAN testers results. It needs to be
    in the same format as, say,
    <http://cpantesters.perl.org/author/MARCEL.html>. You might want to use
    this option if you've already downloaded the relevant file; in this
    case, use a "file://" URI.

    You have to use exactly one of "author()" or "uri()".

  dir
    The directory you want to download the reports to. Mandatory argument;
    does tilde expansion during "run()".

  ignore
    If this argument is given, then, during "run()", every distribution
    whose name matches this regular expression is ignored. You might use
    this when you have deprecated distributions that you don't care about
    anymore, but the reports are still there.

  verbose
    Be more verbose.

  run
    The main method, which is called by the "sync_cpantesters" program. Call
    this after you've set the relevant accessors described above.

    You can add a trigger to this class to filter distributions after they
    have been scraped from the web page and before the individual reports
    are being downloaded. See "TRIGGERS" below.

  get
    Takes a URL, downloads and returns the contents. A progress bar is
    displayed during the download.

  log
    Takes arguments like "sprintf" and prints them only if "verbose()" is
    true. The string will have exactly one newline character at the end.

TRIGGERS
    This class supports a trigger in the style of Class::Trigger.

    dist.filter
        This trigger is called after the data has been scraped from the web
        page but before the individual testing reports are being downloaded.
        The trigger is given an array reference to the distributions; each
        element is a hash that contains the distribution name as well as a
        list of the failure reports.

        For example, suppose you keep the currently maintained distributions
        in a directory and the deprecated ones, the ones you won't support
        anymore, in another directory. Then you might want to download only
        those reports for distributions you maintain. Use something like
        this:

            use App::sync_cpantesters;
            App::sync_cpantesters->add_trigger(
                'dist.filter' => sub {
                    my ($class, $dist) = @_;
                    @$dist = grep { -d "$ENV{HOME}/code/$_->{name}" } @$dist;
                }
            );
            App::sync_cpantesters->new(
                author   => 'MARCEL',
                base_dir => '~/dev/cpan-testers',
                verbose  => 1,
            )->run;

INSTALLATION
    See perlmodinstall for information and options on installing Perl
    modules.

BUGS AND LIMITATIONS
    No bugs have been reported.

    Please report any bugs or feature requests through the web interface at
    <http://rt.cpan.org/Public/Dist/Display.html?Name=App-sync_cpantesters>.

AVAILABILITY
    The latest version of this module is available from the Comprehensive
    Perl Archive Network (CPAN). Visit <http://www.perl.com/CPAN/> to find a
    CPAN site near you, or see
    <http://search.cpan.org/dist/App-sync_cpantesters/>.

    The development version lives at
    <http://github.com/hanekomu/App-sync_cpantesters> and may be cloned from
    <git://github.com/hanekomu/App-sync_cpantesters.git>. Instead of sending
    patches, please fork this project using the standard git and github
    infrastructure.

AUTHOR
    Marcel Gruenauer <marcel@cpan.org>

COPYRIGHT AND LICENSE
    This software is copyright (c) 2007 by Marcel Gruenauer.

    This is free software; you can redistribute it and/or modify it under
    the same terms as the Perl 5 programming language system itself.