Modules

  • ABCDE
  • FGHIL
  • MNOPS
  • TUX

Tools

CPANPLUS::Internals::Report

Perl 5 version 18.0 documentation
Recently read

CPANPLUS::Internals::Report

NAME

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

SYNOPSIS

  1. ### enable test reporting
  2. $cb->configure_object->set_conf( cpantest => 1 );
  3. ### set custom mx host, shouldn't normally be needed
  4. $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:

  1. {
  2. 'grade' => 'PASS',
  3. 'dist' => 'CPANPLUS-0.042',
  4. 'platform' => 'i686-pld-linux-thread-multi'
  5. 'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/98316'
  6. ...
  7. },
  8. {
  9. 'grade' => 'PASS',
  10. 'dist' => 'CPANPLUS-0.042',
  11. 'platform' => 'i686-linux-thread-multi'
  12. 'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99416'
  13. ...
  14. },
  15. {
  16. 'grade' => 'FAIL',
  17. 'dist' => 'CPANPLUS-0.042',
  18. 'platform' => 'cygwin-multi-64int',
  19. 'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99371'
  20. ...
  21. },
  22. {
  23. 'grade' => 'FAIL',
  24. 'dist' => 'CPANPLUS-0.042',
  25. 'platform' => 'i586-linux',
  26. 'details' => 'http://nntp.x.perl.org/group/perl.cpan.testers/99396'
  27. ...
  28. },

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:

  • module

    The module object of this particular distribution

  • buffer

    The output buffer from the 'make/make test' process

  • failed

    Boolean indicating if the 'make/make test' went wrong

  • save

    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.

  • address

    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 .

  • verbose

    Boolean indicating on whether or not to be verbose.

    Defaults to your configuration settings

  • force

    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