NAME

Test::Httpd::Apache2 - Apache2 runner for tests

SYNOPSIS

use Test::Httpd::Apache2;

my $httpd = Test::Httpd::Apache2->new(
    custom_conf => << 'EOT',
DocumentRoot "htdocs"
EOT
);

# do whatever you want
my $url = "http://" . $httpd->listen . "/";
...

DESCRIPTION

The module automatically setups an instance of Apache2 httpd server and destroys it when the perl script exits.

FUNCTIONS

new

Creates and runs the httpd server. Httpd is terminated when the returned object is DESTROYed. The function accepts following arguments, which can also be read and/or be set through the accessors of the same name.

listen

The address to which the httpd binds to. Corresponds to the "Listen" configuration directive of Apache. The default value is "127.0.0.1:<whatever_port_that_was_unused>".

server_root

The "ServerRoot" runtime directive. Set to current working directory if omitted.

custom_conf

Application-specific configuration passed that will be written to the configuration file of Apache. Default is none.

required_modules

An arrayref to specify the required apache modules. If any module are specified, Test::Httpd::Apache2 will check the list of statically-compiled-in and dynamically-aviable modules and load the necessary modules automatically. Module names should be specified excluding the "mod_" prefix and ".so" suffix. For example, auth_basic_module should be specified as "auth_basic". Default is an empty arrayref.

Note: "Authz_host" is automatically translated to "access" if the found httpd is Apache/2.0.x for compatibility.

search_paths

Paths to look for the httpd server in addition to the PATH environment variable. The default is: /usr/sbin, /usr/local/sbin, /usr/local/apache/bin.

pid

the read-only accessor returns pid of the httpd server or undef if it is not running

start

the instance method starts the httpd server

stop

the instance method stops the httpd server

COPYRIGHT

Copyright (C) 2010 Cybozu Labs, Inc. Written by Kazuho Oku.

LICENSE

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

See http://www.perl.com/perl/misc/Artistic.html