Scroll to navigation

CPANPLUS::Internals::Report(3pm) User Contributed Perl Documentation CPANPLUS::Internals::Report(3pm)

NAME

CPANPLUS::Internals::Report - internals for sending test reports

SYNOPSIS

  ### enable test reporting
  $cb->configure_object->set_conf( cpantest => 1 );
  ### set custom mx host, shouldn't normally be needed
  $cb->configure_object->set_conf( cpantest_mx => 'smtp.example.com' );

DESCRIPTION

This module provides all the functionality to send test reports to "http://testers.cpan.org" using the "Test::Reporter" module.

All methods will be called automatically if you have "CPANPLUS" configured to enable test reporting (see the "SYNOPSIS").

METHODS

$bool = $cb->_have_query_report_modules

This function checks if all the required modules are here for querying reports. It returns true and loads them if they are, or returns false otherwise.

$bool = $cb->_have_send_report_modules

This function checks if all the required modules are here for sending reports. It returns true and loads them if they are, or returns false otherwise.

@list = $cb->_query_report( module => $modobj, [all_versions => BOOL, verbose => BOOL] )

This function queries the CPAN testers database at http://testers.cpan.org/ for test results of specified module objects, module names or distributions.

The optional argument "all_versions" controls whether all versions of a given distribution should be grabbed. It defaults to false (fetching only reports for the current version).

Returns the a list with the following data structures (for CPANPLUS version 0.042) on success, or false on failure. The contents of the data structure depends on what http://testers.cpan.org returns, but generally looks like this:

          {
            'grade' => 'PASS',
            'dist' => 'CPANPLUS-0.042',
            'platform' => 'i686-pld-linux-thread-multi'
            'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/98316'
            ...
          },
          {
            'grade' => 'PASS',
            'dist' => 'CPANPLUS-0.042',
            'platform' => 'i686-linux-thread-multi'
            'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99416'
            ...
          },
          {
            'grade' => 'FAIL',
            'dist' => 'CPANPLUS-0.042',
            'platform' => 'cygwin-multi-64int',
            'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99371'
            ...
          },
          {
            'grade' => 'FAIL',
            'dist' => 'CPANPLUS-0.042',
            'platform' => 'i586-linux',
            'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99396'
            ...
          },

The status of the test can be one of the following: UNKNOWN, PASS, FAIL or NA (not applicable).

$bool = $cb->_send_report( module => $modobj, buffer => $make_output, failed => BOOL, [save => BOOL, address => $email_to, verbose => BOOL, force => BOOL]);

This function sends a testers report to "cpan-testers@perl.org" for a particular distribution. It returns true on success, and false on failure.

It takes the following options:

The module object of this particular distribution
The output buffer from the 'make/make test' process
Boolean indicating if the 'make/make test' went wrong
Boolean indicating if the report should be saved locally instead of mailed out. If provided, this function will return the location the report was saved to, rather than a simple boolean 'TRUE'.

Defaults to false.

The email address to mail the report for. You should never need to override this, but it might be useful for debugging purposes.

Defaults to "cpan-testers@perl.org".

Boolean indicating on whether or not to be verbose.

Defaults to your configuration settings

Boolean indicating whether to force the sending, even if the max amount of reports for fails have already been reached, or if you may already have sent it before.

Defaults to your configuration settings

2021-11-24 perl v5.32.1