ABCDEFGHIJKLMNOPQRSTUVWXYZ

Apache::TestUtil

Apache::TestUtil(3)   User Contributed Perl Documentation  Apache::TestUtil(3)



NAME
       Apache::TestUtil - Utility functions for writing tests

SYNOPSIS
         use Apache::Test;
         use Apache::TestUtil;

         ok t_cmp("foo", "foo", "sanity check");
         t_write_file("filename", @content);
         my $fh = t_open_file($filename);
         t_mkdir("/foo/bar");
         t_rmtree("/foo/bar");
         t_is_equal($a, $b);

DESCRIPTION
       "Apache::TestUtil" automatically exports a number of functions useful
       in writing tests.

       All the files and directories created using the functions from this
       package will be automatically destroyed at the end of the program exe-
       cution (via END block). You should not use these functions other than
       from within tests which should cleanup all the created directories and
       files at the end of the test.

FUNCTIONS
       t_cmp()
             t_cmp($expected, $received, $comment);

           t_cmp() prints the values of $comment, $expected and $received.
           e.g.:

             t_cmp(1, 1, "1 == 1?");

           prints:

             # testing : 1 == 1?
             # expected: 1
             # received: 1

           then it returns the result of comparison of the $expected and the
           $received variables. Usually, the return value of this function is
           fed directly to the ok() function, like this:

             ok t_cmp(1, 1, "1 == 1?");

           the third argument ($comment) is optional, mostly useful for
           telling what the comparison is trying to do.

           It is valid to use "undef" as an expected value. Therefore:

             my $foo;
             t_cmp(undef, $foo, "undef == undef?");

           will return a true value.

           You can compare any two data-structures with t_cmp(). Just make
           sure that if you pass non-scalars, you have to pass their refer-
           ences. The datastructures can be deeply nested. For example you can
           compare:

             t_cmp({1 => [2..3,{5..8}], 4 => [5..6]},
                   {1 => [2..3,{5..8}], 4 => [5..6]},
                   "hash of array of hashes");

           You can also compare the second argument against the first as a
           regex. Use the "qr//" function in the first argument. For example:

             t_cmp(qr/^abc/, "abcd", "regex compare");

           will do:

             "abcd" =~ /^abc/;

           This function is exported by default.

       t_debug()
             t_debug("testing feature foo");
             t_debug("test", [1..3], 5, {a=>[1..5]});

           t_debug() prints out any datastructure while prepending "#" at the
           beginning of each line, to make the debug printouts comply with
           "Test::Harness"'s requirements. This function should be always used
           for debug prints, since if in the future the debug printing will
           change (e.g. redirected into a file) your tests won't need to be
           changed.

           This function is exported by default.

       t_write_file()
             t_write_file($filename, @lines);

           t_write_file() creates a new file at $filename or overwrites the
           existing file with the content passed in @lines. If only the $file-
           name is passed, an empty file will be created.

           If parent directories of $filename don't exist they will be
           automagically created.

           The generated file will be automatically deleted at the end of the
           program's execution.

           This function is exported by default.

       write_shell_script()
             write_shell_script($filename, @lines);

           Similar to t_write_file() but creates a portable shell/batch
           script. The created filename is constructed from $filename and an
           appropriate extension automatically selected according to the plat-
           form the code is running under.

           It returns the extension of the created file.

       write_perl_script()
             write_perl_script($filename, @lines);

           Similar to t_write_file() but creates a executable Perl script with
           correctly set shebang line.

       t_open_file()
             my $fh = t_open_file($filename);

           t_open_file() opens a file $filename for writing and returns the
           file handle to the opened file.

           If parent directories of $filename don't exist they will be
           automagically created.

           The generated file will be automatically deleted at the end of the
           program's execution.

           This function is exported by default.

       t_mkdir()
             t_mkdir($dirname);

           t_mkdir() creates a directory $dirname. The operation will fail if
           the parent directory doesn't exist.

           If parent directories of $dirname don't exist they will be automag-
           ically created.

           The generated directory will be automatically deleted at the end of
           the program's execution.

           This function is exported by default.

       t_rmtree()
             t_rmtree(@dirs);

           t_rmtree() deletes the whole directories trees passed in @dirs.

           This function is exported by default.

       chown()
             Apache::TestUtil::chown($file);

           Change ownership of $file to the test's User/Group.  This function
           is noop on platforms where chown(2) is unsupported (e.g. Win32).

       t_is_equal()
             t_is_equal($a, $b);

           t_is_equal() compares any two datastructures and returns 1 if they
           are exactly the same, otherwise 0. The datastructures can be nested
           hashes, arrays, scalars, undefs or a combination of any of these.
           See t_cmp() for an example.

           If $a is a regex reference, the regex comparison "$b =~ $a" is per-
           formed. For example:

             t_is_equal(qr{^Apache}, $server_version);

           If comparing non-scalars make sure to pass the references to the
           datastructures.

           This function is exported by default.

AUTHOR
       Stas Bekman <stas@stason.org>

SEE ALSO
       perl(1)



perl v5.8.0                       2002-01-06               Apache::TestUtil(3)