NAME

Test::WWW::Mechanize - Testing-specific WWW::Mechanize subclass

Version

Version 1.00

SYNOPSIS

Test::WWW::Mechanize is a subclass of WWW::Mechanize that incorporates features for web application testing. For example:

$mech->get( $page );
$mech->title_is( "Invoice Status", "Make sure we're on the invoice page" );
$mech->content_contains( "Andy Lester", "My name somewhere" );
$mech->content_like( qr/(cpan|perl)\.org/, "Link to perl.org or CPAN" );

This is equivalent to:

$mech->get( $page );
is( $mech->title, "Invoice Status", "Make sure we're on the invoice page" );
ok( index( $mech->content, "Andy Lester" ) >= 0, "My name somewhere" );
like( $mech->content, qr/(cpan|perl)\.org/, "Link to perl.org or CPAN" );

but has nicer diagnostics if they fail.

Constructor

new

Behaves like, and calls, WWW::Mechanize's new method. Any parms passed in get passed to WWW::Mechanize's constructor.

Methods

title_is( $str [, $msg ] )

Tells if the title of the page is the given string.

$mech->title_is( "Invoice Summary" );

title_like( $regex [, $msg ] )

Tells if the title of the page matches the given regex.

$mech->title_like( qr/Invoices for (.+)/

title_unlike( $regex [, $msg ] )

Tells if the title of the page matches the given regex.

$mech->title_unlike( qr/Invoices for (.+)/

content_is( $str [, $msg ] )

Tells if the content of the page matches the given string

content_contains( $str [, $msg ] )

Tells if the content of the page contains the given string

content_like( $regex [, $msg ] )

Tells if the content of the page matches the given regex

content_unlike( $regex [, $msg ] )

Tells if the content of the page matches the given regex

Follow all links on the current page and test for HTTP status 200

$mech->page_links_ok('Check all links');

Follow all links on the current page and test their contents for the specified regex.

$mech->page_links_content_like(qr/html/,
  'Check all links contain html');

Follow all links on the current page and test their contents do not contain the specified regex.

$mech->page_links_content_unlike(qr/Restricted/,
  'Check all links do not contain Restricted');

Check the current page for specified links and test for HTTP status 200. The links may be specified as a reference to an array containing WWW::Mechanize::Link objects, an array of URLs, or a scalar URL name.

my @links = $mech->find_all_links( url_regex => qr/cnn\.com$/ );
$mech->links_ok( \@links, 'Check all links for cnn.com' );

my @links = qw( index.html search.html about.html );
$mech->links_ok( \@links, 'Check main links' );

$mech->links_ok( 'index.html', 'Check link to index' );

Check the current page for specified links and test for HTTP status passed. The links may be specified as a reference to an array containing WWW::Mechanize::Link objects, an array of URLs, or a scalar URL name.

my @links = $mech->links();
$mech->link_status_is( \@links, 403,
  'Check all links are restricted' );

Check the current page for specified links and test for HTTP status passed. The links may be specified as a reference to an array containing WWW::Mechanize::Link objects, an array of URLs, or a scalar URL name.

my @links = $mech->links();
$mech->link_status_isnt( \@links, 404,
  'Check all links are not 404' );

Check the current page for specified links and test the content of each for the regex passed. The links may be specified as a reference to an array containing WWW::Mechanize::Link objects, an array of URLs, or a scalar URL name.

my @links = $mech->links();
$mech->link_content_like( \@links, qr/Restricted/,
    'Check all links are restricted' );

Check the current page for specified links and test the content of each does not contain regex passed. The links may be specified as a reference to an array containing WWW::Mechanize::Link objects, an array of URLs, or a scalar URL name.

my @links = $mech->links();
$mech->link_content_like( \@links, qr/Restricted/,
  'Check all links are restricted' );

To-do

  • Test suite

  • Add HTML::Lint and HTML::Tidy capabilities.

BUGS

Please report any bugs or feature requests to bug-test-www-mechanize@rt.cpan.org, or through the web interface at http://rt.cpan.org. I will be notified, and then you'll automatically be notified of progress on your bug as I make changes.

COPYRIGHT & LICENSE

Copyright 2004 Andy Lester, All Rights Reserved.

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

AUTHOR

Andy Lester, <andy@petdance.com>

ACKNOWLEDGEMENTS

Thanks to Shawn Sorichetti for big help and chunks of code.