PATH=/opt/SUNWspro/bin:/usr/local/bin:/opt/csw/bin:/usr/ccs/bin:/usr/bin:/usr/sbin Start 2013-09-07T02:29:11 ActivePerl-1402 CPAN-2.00 Reading '/export/home/fly1432/var/cpan/Metadata' Database was generated on Sat, 07 Sep 2013 07:07:35 GMT Running make for D/DA/DAGOLDEN/Path-Tiny-0.032.tar.gz Checksum for /net/nas/data/cpan/authors/id/D/DA/DAGOLDEN/Path-Tiny-0.032.tar.gz ok Path-Tiny-0.032/ Path-Tiny-0.032/Changes Path-Tiny-0.032/CONTRIBUTING Path-Tiny-0.032/cpanfile Path-Tiny-0.032/dist.ini Path-Tiny-0.032/lib/ Path-Tiny-0.032/LICENSE Path-Tiny-0.032/Makefile.PL Path-Tiny-0.032/MANIFEST Path-Tiny-0.032/META.json Path-Tiny-0.032/META.yml Path-Tiny-0.032/perlcritic.rc Path-Tiny-0.032/README Path-Tiny-0.032/t/ Path-Tiny-0.032/tidyall.ini Path-Tiny-0.032/xt/ Path-Tiny-0.032/xt/author/ Path-Tiny-0.032/xt/release/ Path-Tiny-0.032/xt/release/distmeta.t Path-Tiny-0.032/xt/release/minimum-version.t Path-Tiny-0.032/xt/release/pod-coverage.t Path-Tiny-0.032/xt/release/pod-syntax.t Path-Tiny-0.032/xt/release/portability.t Path-Tiny-0.032/xt/release/test-version.t Path-Tiny-0.032/xt/author/critic.t Path-Tiny-0.032/xt/author/pod-spell.t Path-Tiny-0.032/t/00-compile.t Path-Tiny-0.032/t/00-report-prereqs.t Path-Tiny-0.032/t/basic.t Path-Tiny-0.032/t/children.t Path-Tiny-0.032/t/digest.t Path-Tiny-0.032/t/exception.t Path-Tiny-0.032/t/exports.t Path-Tiny-0.032/t/filesystem.t Path-Tiny-0.032/t/input_output.t Path-Tiny-0.032/t/input_output_no_UU.t Path-Tiny-0.032/t/lib/ Path-Tiny-0.032/t/mkpath.t Path-Tiny-0.032/t/normalize.t Path-Tiny-0.032/t/overloading.t Path-Tiny-0.032/t/parent.t Path-Tiny-0.032/t/README Path-Tiny-0.032/t/recurse.t Path-Tiny-0.032/t/rel-abs.t Path-Tiny-0.032/t/temp.t Path-Tiny-0.032/t/zzz-spec.t Path-Tiny-0.032/t/lib/TestUtils.pm Path-Tiny-0.032/lib/Path/ Path-Tiny-0.032/lib/Path/Tiny.pm CPAN.pm: Building D/DA/DAGOLDEN/Path-Tiny-0.032.tar.gz >>> /export/home/fly1432/bin/perl Makefile.PL Checking if your kit is complete... Looks good Generating a GNU-style Makefile Writing Makefile for Path::Tiny Writing MYMETA.yml and MYMETA.json >>> make cp lib/Path/Tiny.pm blib/lib/Path/Tiny.pm Manifying blib/man3/Path::Tiny.3 DAGOLDEN/Path-Tiny-0.032.tar.gz make -- OK Running make test >>> make test TEST_VERBOSE=1 PERL_DL_NONLAZY=1 /export/home/fly1432/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(1, 'blib/lib', 'blib/arch')" t/*.t t/00-compile.t .......... 1..1 ok 1 - Path/Tiny.pm loaded ok ok # Prerequisite Report: # Version Module # ------- --------------------- # 1.32 Carp # 3.40 Cwd # 1.17 Digest # 5.85 Digest::SHA # 5.68 Exporter # 6.76 ExtUtils::MakeMaker # 1.11 Fcntl # 2.82 File::Basename # 2.21 File::Copy # 2.09 File::Path # 3.40 File::Spec # 3.40 File::Spec::Functions # 3.40 File::Spec::Unix # 0.2301 File::Temp # 1.05 File::stat # 1.28 IO::Handle # 1.09 IPC::Open3 # 1.32 List::Util # 0.007 Test::FailWarnings # 0.98 Test::More # 0.59 Unicode::UTF8 # 2.20 autodie::exception # 1.27 constant # 0.63 lib # 1.08 open # 1.13 overload # 1.04 strict # 1.87 threads # 1.12 warnings t/00-report-prereqs.t ... 1..1 ok 1 ok t/basic.t ............... ok 1 - The object isa Path::Tiny ok 2 ok 3 ok 4 ok 5 ok 6 ok 7 ok 8 ok 9 ok 10 ok 11 ok 12 ok 13 ok 14 ok 15 ok 16 ok 17 ok 18 ok 19 ok 20 ok 21 ok 22 - The object isa Path::Tiny ok 23 ok 24 ok 25 - The object isa Path::Tiny ok 26 ok 27 ok 28 ok 29 ok 30 - canonpath ok 31 ok 32 ok 33 ok 34 ok 35 ok 36 ok 37 ok 38 ok 39 ok 40 ok 41 ok 42 - exception ok 43 - exception ok 44 - exception ok 45 - exception ok 46 ok 47 ok 48 ok 49 ok 50 ok 51 ok 52 ok 53 - rootdir is like path('/') ok 54 - child of rootdir is correct ok 55 - path() vs new ok 56 - path(a,b,c) vs path('a/b/c') ok 57 - Test my homedir ok 58 - Test my homedir with trailing "/" ok 59 - Test my homedir with longer path ok 60 - Test my homedir, longer path and trailing "/" ok 61 - Test root homedir ok 62 - Test root homedir with trailing / ok 63 - Test root homedir with longer path ok 64 - Test root homedir, longer path and trailing "/" ok 65 - Test homedir of nonexistant user ok 66 - Test homedir of nonexistant user (via glob) 1..66 ok t/children.t ............ ok 1 - children correct ok 2 - children correct with Regexp argument ok 3 - children with invalid argument 1..3 ok t/digest.t .............. ok 1 - created test file with packed binary string ok 2 - digest SHA-256 (hardcoded) ok 3 - digest SHA-256 ok 4 - digest MD5 (hardcoded) ok 5 - digest MD5 1..5 ok t/exception.t ........... ok 1 - exception reported at caller's package ok 2 - append bad args ok 3 - iterator bad args ok 4 - lines bad args ok 5 - lines_raw bad args ok 6 - lines_utf8 bad args ok 7 - slurp bad args ok 8 - spew bad args ok 9 - iterator not hashref ok 10 - lines not hashref ok 11 - lines_raw not hashref ok 12 - lines_utf8 not hashref ok 13 - slurp not hashref 1..13 ok t/exports.t ............. ok 1 - path isa Path::Tiny ok 2 - cwd isa Path::Tiny ok 3 - rootdir isa Path::Tiny ok 4 - tempfile isa Path::Tiny ok 5 - tempdir isa Path::Tiny 1..5 ok t/filesystem.t .......... ok 1 - Got a filename via tmpnam() ok 2 - Opened /tmp/NujxLv99B6 for writing ok 3 - Printed to /tmp/NujxLv99B6 ok 4 - /tmp/NujxLv99B6 should exist ok 5 - it's a file! ok 6 - volume correct ok 7 - volume cached ok 8 - dirname correct ok 9 - basename correct ok 10 - Read contents of /tmp/NujxLv99B6 correctly # stat ok 11 ok 12 ok 13 # stat/lstat with no file ok 14 ok 15 ok 16 ok 17 ok 18 ok 19 - It's a directory! ok 20 ok 21 - touch sets utime as current time ok 22 - touch sets utime as 10 secs before ok 23 ok 24 ok 25 - Removed /tmp/34CPS03WvQ ok 26 - /tmp/34CPS03WvQ no longer exists ok 27 - Removing non-existent dir returns false ok 28 - Created /tmp/hdSkLnHbC5/foo/bar ok 29 - /tmp/hdSkLnHbC5/foo/bar is a directory ok 30 ok 31 ok 32 ok 33 ok 34 ok 35 ok 36 ok 37 ok 38 ok 39 - exhausted iterator is undef ok 40 ok 41 ok 42 ok 43 ok 44 ok 45 ok 46 ok 47 ok 48 ok 49 ok 50 ok 51 ok 52 ok 53 ok 54 ok 55 ok 56 ok 57 ok 58 ok 59 ok 60 - removing file ok 61 - file is gone ok 62 - removing file again returns false ok 63 ok 64 ok 65 - slurp raw ok 66 - slurp+crlf+utf8 ok 67 - lines+crlf+utf8 ok 68 - lines+chomp+crlf+utf8 ok 69 ok 70 ok 71 - from . to /data1/fly1432-var/cpan/build/Path-Tiny-0.032-Ul1Y7G to . ok 72 - updir gone from realpath ok 73 - realpath on absolute ok 74 - file copied ok 75 - copy throws error if permission denied ok 76 - error messages includes the source file name ok 77 - error messages includes the destination file name ok 78 - touch can chain ok 79 - lstat ok 80 - remove symbolic link ok 81 ok 82 ok 83 ok 84 - remove broken symbolic link ok 85 ok 86 ok 87 ok 88 - remove_tree symbolic link ok 89 ok 90 ok 91 ok 92 ok 93 ok 94 - remove_tree broken symbolic link ok 95 ok 96 ok 97 - path is still symbolic link after spewing ok 98 - symbolic link is available after spewing ok 99 - symbolic link is available after spewing ok 100 - spewing follows the link and replace the destination instead 1..100 ok t/input_output.t ........ ok 1 - spew ok 2 - slurp 1..2 ok 1 - spew -> slurp ok 1 - spew ok 2 - slurp 1..2 ok 2 - spew -> slurp (empty) ok 1 - spew ok 2 - slurp 1..2 ok 3 - spew -> slurp (arrayref) ok 1 - spew ok 2 - slurp 1..2 ok 4 - spew -> slurp (binmode) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 5 - spew -> slurp (open hint) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 6 - spew -> slurp (UTF-8) ok 1 - spew ok 2 - slurp 1..2 ok 7 - spew -> slurp (raw) ok 1 - spew ok 2 - lines ok 3 - lines (scalar) 1..3 ok 8 - spew -> lines ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 9 - spew -> lines (open hint) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 ok 4 - lines (scalar) 1..4 ok 10 - spew -> lines (UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 11 - spew -> lines (raw) ok 1 - spew ok 2 - lines 1..2 ok 12 - spew -> lines (count) ok 1 - spew ok 2 - lines 1..2 ok 13 - spew -> lines (count, less than) ok 1 - spew ok 2 - lines 1..2 ok 14 - spew -> lines (count, more than) ok 1 - spew ok 2 - lines 1..2 ok 15 - spew -> lines (count, chomp) ok 1 - spew ok 2 - lines 1..2 ok 16 - spew -> lines (count, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 17 - spew -> lines (count, chomp, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 18 - spew -> lines (chomp, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 19 - spew -> lines (count, raw) ok 1 - append ok 2 - slurp 1..2 ok 20 - append -> slurp ok 1 - append ok 2 - slurp 1..2 ok 21 - append -> slurp (empty) ok 1 - append ok 2 - slurp 1..2 ok 22 - append -> slurp (arrayref) ok 1 - piecemeal append ok 2 - piecemeal append ok 3 - slurp 1..3 ok 23 - append -> slurp (piecemeal) ok 1 - append ok 2 - slurp 1..2 ok 24 - append -> slurp (binmode) ok 1 - append ok 2 - slurp 1..2 ok 25 - append -> slurp (open hint) ok 1 - append ok 2 - slurp 1..2 ok 26 - append -> slurp (UTF-8) ok 1 - append ok 2 - slurp 1..2 ok 27 - append -> slurp (raw) ok 1 - openw & print ok 2 - openr & read 1..2 ok 28 - openw -> openr ok 1 - openw & print ok 2 - openr & read ok 3 - is UTF8 1..3 ok 29 - openw -> openr (open hint) ok 1 - openw & print ok 2 - openr & read ok 3 - is UTF8 1..3 ok 30 - openw -> openr (UTF-8) ok 1 - openw & print ok 2 - openr & read 1..2 ok 31 - openw -> openr (raw) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read 1..3 ok 32 - opena -> openr ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read ok 4 - is UTF8 1..4 ok 33 - opena -> openr (open hint) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read ok 4 - is UTF8 1..4 ok 34 - opena -> openr (UTF-8) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read 1..3 ok 35 - opena -> openr (raw) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read 1..3 ok 36 - openrw ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read ok 4 - is UTF8 1..4 ok 37 - openrw (open hint) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read ok 4 - is UTF8 1..4 ok 38 - openrw (UTF-8) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read 1..3 ok 39 - openrw (raw) 1..39 ok t/input_output_no_UU.t .. # Hiding Unicode::UTF8 ok 1 - spew ok 2 - slurp 1..2 ok 1 - spew -> slurp ok 1 - spew ok 2 - slurp 1..2 ok 2 - spew -> slurp (empty) ok 1 - spew ok 2 - slurp 1..2 ok 3 - spew -> slurp (arrayref) ok 1 - spew ok 2 - slurp 1..2 ok 4 - spew -> slurp (binmode) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 5 - spew -> slurp (open hint) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 6 - spew -> slurp (UTF-8) ok 1 - spew ok 2 - slurp 1..2 ok 7 - spew -> slurp (raw) ok 1 - spew ok 2 - lines ok 3 - lines (scalar) 1..3 ok 8 - spew -> lines ok 1 - spew ok 2 - slurp ok 3 - is UTF8 1..3 ok 9 - spew -> lines (open hint) ok 1 - spew ok 2 - slurp ok 3 - is UTF8 ok 4 - lines (scalar) 1..4 ok 10 - spew -> lines (UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 11 - spew -> lines (raw) ok 1 - spew ok 2 - lines 1..2 ok 12 - spew -> lines (count) ok 1 - spew ok 2 - lines 1..2 ok 13 - spew -> lines (count, less than) ok 1 - spew ok 2 - lines 1..2 ok 14 - spew -> lines (count, more than) ok 1 - spew ok 2 - lines 1..2 ok 15 - spew -> lines (count, chomp) ok 1 - spew ok 2 - lines 1..2 ok 16 - spew -> lines (count, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 17 - spew -> lines (count, chomp, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 18 - spew -> lines (chomp, UTF-8) ok 1 - spew ok 2 - lines 1..2 ok 19 - spew -> lines (count, raw) ok 1 - append ok 2 - slurp 1..2 ok 20 - append -> slurp ok 1 - append ok 2 - slurp 1..2 ok 21 - append -> slurp (empty) ok 1 - append ok 2 - slurp 1..2 ok 22 - append -> slurp (arrayref) ok 1 - piecemeal append ok 2 - piecemeal append ok 3 - slurp 1..3 ok 23 - append -> slurp (piecemeal) ok 1 - append ok 2 - slurp 1..2 ok 24 - append -> slurp (binmode) ok 1 - append ok 2 - slurp 1..2 ok 25 - append -> slurp (open hint) ok 1 - append ok 2 - slurp 1..2 ok 26 - append -> slurp (UTF-8) ok 1 - append ok 2 - slurp 1..2 ok 27 - append -> slurp (raw) ok 1 - openw & print ok 2 - openr & read 1..2 ok 28 - openw -> openr ok 1 - openw & print ok 2 - openr & read ok 3 - is UTF8 1..3 ok 29 - openw -> openr (open hint) ok 1 - openw & print ok 2 - openr & read ok 3 - is UTF8 1..3 ok 30 - openw -> openr (UTF-8) ok 1 - openw & print ok 2 - openr & read 1..2 ok 31 - openw -> openr (raw) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read 1..3 ok 32 - opena -> openr ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read ok 4 - is UTF8 1..4 ok 33 - opena -> openr (open hint) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read ok 4 - is UTF8 1..4 ok 34 - opena -> openr (UTF-8) ok 1 - openw & print one line ok 2 - opena & print rest of lines ok 3 - openr & read 1..3 ok 35 - opena -> openr (raw) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read 1..3 ok 36 - openrw ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read ok 4 - is UTF8 1..4 ok 37 - openrw (open hint) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read ok 4 - is UTF8 1..4 ok 38 - openrw (UTF-8) ok 1 - openrw & print ok 2 - seek back to start ok 3 - openr & read 1..3 ok 39 - openrw (raw) 1..39 ok t/mkpath.t .............. ok 1 - target directory not created yet ok 2 - mkpath on directory returned true ok 3 - target directory created ok 4 - target directory not created yet ok 5 - mkpath on directory with mode ok 6 - correct mode ok 7 - target directory created 1..7 ok t/normalize.t ........... ok 1 - . -> . ok 2 - ./ -> . ok 3 - / -> / ok 4 - /. -> / ok 5 - .. -> .. ok 6 - /.. -> / ok 7 - ../ -> .. ok 8 - ../.. -> ../.. ok 9 - /./ -> / ok 10 - /foo/ -> /foo ok 11 - foo/ -> foo ok 12 - ./foo -> foo ok 13 - foo/. -> foo 1..13 ok t/overloading.t ......... ok 1 - stringify via overloading ok 2 - stringify via method ok 3 - boolifies to true 1..3 ok t/parent.t .............. ok 1 - parent(undef): /foo/bar -> /foo ok 2 - parent(0): /foo/bar -> /foo ok 3 - parent(1): /foo/bar -> /foo ok 4 - parent(2): /foo/bar -> / ok 5 - parent(3): /foo/bar -> / ok 6 - parent(undef): /foo -> / ok 7 - parent(0): /foo -> / ok 8 - parent(1): /foo -> / ok 9 - parent(2): /foo -> / ok 10 - parent(undef): / -> / ok 11 - parent(0): / -> / ok 12 - parent(1): / -> / 1..12 ok 1 - absolute ok 1 - parent(undef): foo/bar/baz -> foo/bar ok 2 - parent(0): foo/bar/baz -> foo/bar ok 3 - parent(1): foo/bar/baz -> foo/bar ok 4 - parent(2): foo/bar/baz -> foo ok 5 - parent(3): foo/bar/baz -> . ok 6 - parent(4): foo/bar/baz -> .. ok 7 - parent(5): foo/bar/baz -> ../.. ok 8 - parent(6): foo/bar/baz -> ../../.. ok 9 - parent(undef): foo/bar -> foo ok 10 - parent(0): foo/bar -> foo ok 11 - parent(1): foo/bar -> foo ok 12 - parent(2): foo/bar -> . ok 13 - parent(3): foo/bar -> .. ok 14 - parent(4): foo/bar -> ../.. ok 15 - parent(5): foo/bar -> ../../.. ok 16 - parent(undef): foo -> . ok 17 - parent(0): foo -> . ok 18 - parent(1): foo -> . ok 19 - parent(2): foo -> .. ok 20 - parent(3): foo -> ../.. ok 21 - parent(4): foo -> ../../.. ok 22 - parent(undef): . -> .. ok 23 - parent(0): . -> .. ok 24 - parent(1): . -> .. ok 25 - parent(2): . -> ../.. ok 26 - parent(3): . -> ../../.. ok 27 - parent(undef): .. -> ../.. ok 28 - parent(0): .. -> ../.. ok 29 - parent(1): .. -> ../.. ok 30 - parent(2): .. -> ../../.. ok 31 - parent(undef): ../.. -> ../../.. ok 32 - parent(0): ../.. -> ../../.. ok 33 - parent(1): ../.. -> ../../.. 1..33 ok 2 - relative ok 1 - parent(undef): /foo/bar/../baz -> /foo/bar/.. ok 2 - parent(0): /foo/bar/../baz -> /foo/bar/.. ok 3 - parent(1): /foo/bar/../baz -> /foo/bar/.. ok 4 - parent(2): /foo/bar/../baz -> /foo/bar/../.. ok 5 - parent(3): /foo/bar/../baz -> /foo/bar/../../.. ok 6 - parent(undef): /foo/bar/.. -> /foo/bar/../.. ok 7 - parent(0): /foo/bar/.. -> /foo/bar/../.. ok 8 - parent(1): /foo/bar/.. -> /foo/bar/../.. ok 9 - parent(2): /foo/bar/.. -> /foo/bar/../../.. ok 10 - parent(undef): /foo/bar/../.. -> /foo/bar/../../.. ok 11 - parent(0): /foo/bar/../.. -> /foo/bar/../../.. ok 12 - parent(1): /foo/bar/../.. -> /foo/bar/../../.. 1..12 ok 3 - absolute with .. ok 1 - parent(undef): foo/bar/../baz -> foo/bar/.. ok 2 - parent(0): foo/bar/../baz -> foo/bar/.. ok 3 - parent(1): foo/bar/../baz -> foo/bar/.. ok 4 - parent(2): foo/bar/../baz -> foo/bar/../.. ok 5 - parent(3): foo/bar/../baz -> foo/bar/../../.. ok 6 - parent(undef): foo/bar/.. -> foo/bar/../.. ok 7 - parent(0): foo/bar/.. -> foo/bar/../.. ok 8 - parent(1): foo/bar/.. -> foo/bar/../.. ok 9 - parent(2): foo/bar/.. -> foo/bar/../../.. ok 10 - parent(undef): foo/bar/../.. -> foo/bar/../../.. ok 11 - parent(0): foo/bar/../.. -> foo/bar/../../.. ok 12 - parent(1): foo/bar/../.. -> foo/bar/../../.. 1..12 ok 4 - relative with .. ok 1 - parent(undef): ../foo/bar -> ../foo ok 2 - parent(0): ../foo/bar -> ../foo ok 3 - parent(1): ../foo/bar -> ../foo ok 4 - parent(2): ../foo/bar -> .. ok 5 - parent(3): ../foo/bar -> ../.. ok 6 - parent(undef): ../foo -> .. ok 7 - parent(0): ../foo -> .. ok 8 - parent(1): ../foo -> .. ok 9 - parent(2): ../foo -> ../.. ok 10 - parent(undef): .. -> ../.. ok 11 - parent(0): .. -> ../.. ok 12 - parent(1): .. -> ../.. 1..12 ok 5 - relative with leading .. ok 1 - parent(undef): /foo..bar/baz..bam -> /foo..bar ok 2 - parent(0): /foo..bar/baz..bam -> /foo..bar ok 3 - parent(1): /foo..bar/baz..bam -> /foo..bar ok 4 - parent(2): /foo..bar/baz..bam -> / ok 5 - parent(undef): /foo..bar -> / ok 6 - parent(0): /foo..bar -> / ok 7 - parent(1): /foo..bar -> / 1..7 ok 6 - absolute with internal dots ok 1 - parent(undef): foo/bar..baz/wib..wob -> foo/bar..baz ok 2 - parent(0): foo/bar..baz/wib..wob -> foo/bar..baz ok 3 - parent(1): foo/bar..baz/wib..wob -> foo/bar..baz ok 4 - parent(2): foo/bar..baz/wib..wob -> foo ok 5 - parent(3): foo/bar..baz/wib..wob -> . ok 6 - parent(4): foo/bar..baz/wib..wob -> .. ok 7 - parent(undef): foo/bar..baz -> foo ok 8 - parent(0): foo/bar..baz -> foo ok 9 - parent(1): foo/bar..baz -> foo ok 10 - parent(2): foo/bar..baz -> . ok 11 - parent(3): foo/bar..baz -> .. ok 12 - parent(undef): foo -> . ok 13 - parent(0): foo -> . ok 14 - parent(1): foo -> . ok 15 - parent(2): foo -> .. ok 16 - parent(undef): . -> .. ok 17 - parent(0): . -> .. ok 18 - parent(1): . -> .. 1..18 ok 7 - relative with internal dots ok 1 - parent(undef): /..foo/..bar -> /..foo ok 2 - parent(0): /..foo/..bar -> /..foo ok 3 - parent(1): /..foo/..bar -> /..foo ok 4 - parent(2): /..foo/..bar -> / ok 5 - parent(undef): /..foo -> / ok 6 - parent(0): /..foo -> / ok 7 - parent(1): /..foo -> / 1..7 ok 8 - absolute with leading dots ok 1 - parent(undef): ..foo/..bar/..wob -> ..foo/..bar ok 2 - parent(0): ..foo/..bar/..wob -> ..foo/..bar ok 3 - parent(1): ..foo/..bar/..wob -> ..foo/..bar ok 4 - parent(2): ..foo/..bar/..wob -> ..foo ok 5 - parent(3): ..foo/..bar/..wob -> . ok 6 - parent(4): ..foo/..bar/..wob -> .. ok 7 - parent(undef): ..foo/..bar -> ..foo ok 8 - parent(0): ..foo/..bar -> ..foo ok 9 - parent(1): ..foo/..bar -> ..foo ok 10 - parent(2): ..foo/..bar -> . ok 11 - parent(3): ..foo/..bar -> .. ok 12 - parent(undef): ..foo -> . ok 13 - parent(0): ..foo -> . ok 14 - parent(1): ..foo -> . ok 15 - parent(2): ..foo -> .. ok 16 - parent(undef): . -> .. ok 17 - parent(0): . -> .. ok 18 - parent(1): . -> .. 1..18 ok 9 - relative with leading dots ok 1 - parent(undef): /foo../bar.. -> /foo.. ok 2 - parent(0): /foo../bar.. -> /foo.. ok 3 - parent(1): /foo../bar.. -> /foo.. ok 4 - parent(2): /foo../bar.. -> / ok 5 - parent(undef): /foo.. -> / ok 6 - parent(0): /foo.. -> / ok 7 - parent(1): /foo.. -> / 1..7 ok 10 - absolute with trailing dots ok 1 - parent(undef): foo../bar../wob.. -> foo../bar.. ok 2 - parent(0): foo../bar../wob.. -> foo../bar.. ok 3 - parent(1): foo../bar../wob.. -> foo../bar.. ok 4 - parent(2): foo../bar../wob.. -> foo.. ok 5 - parent(3): foo../bar../wob.. -> . ok 6 - parent(4): foo../bar../wob.. -> .. ok 7 - parent(undef): foo../bar.. -> foo.. ok 8 - parent(0): foo../bar.. -> foo.. ok 9 - parent(1): foo../bar.. -> foo.. ok 10 - parent(2): foo../bar.. -> . ok 11 - parent(3): foo../bar.. -> .. ok 12 - parent(undef): foo.. -> . ok 13 - parent(0): foo.. -> . ok 14 - parent(1): foo.. -> . ok 15 - parent(2): foo.. -> .. ok 16 - parent(undef): . -> .. ok 17 - parent(0): . -> .. ok 18 - parent(1): . -> .. 1..18 ok 11 - relative with trailing dots 1..11 ok t/recurse.t ............. ok 1 - Breadth first iteration 1..1 ok 1 - no symlinks ok 1 - Don't follow symlinks 1..1 ok 1 - no follow ok 1 - Follow symlinks 1..1 ok 2 - follow 1..2 ok 2 - with symlinks 1..2 ok t/rel-abs.t ............. ok 1 - absolute of absolute is identity ok 2 - absolute on base 1..2 ok t/temp.t ................ ok 1 - tempdir exists ok 2 - tempdir destroyed 1..2 ok 1 - tempdir ok 1 - tempfile exists ok 2 - tempfile destroyed 1..2 ok 2 - tempfile ok 1 - found template 1..1 ok 3 - tempdir w/ TEMPLATE ok 1 - found template 1..1 ok 4 - tempfile w/ TEMPLATE ok 1 - found template 1..1 ok 5 - tempdir w/ leading template ok 1 - found template 1..1 ok 6 - tempfile w/ leading template ok 1 - cached File::Temp object ok 2 - cached handle is closed 1..2 ok 7 - tempfile handle ok 1 - exists 1..1 ok 8 - survives absolute 1..8 ok t/zzz-spec.t ............ ok 1 - path('a','b','c') ok 2 - path('a','b','./c') ok 3 - path('./a','b','c') ok 4 - path('c') ok 5 - path('./c') ok 6 - path('/') ok 7 - path('d1','d2','d3','') ok 8 - path('d1','d2','d3') ok 9 - path('/','d2/d3') ok 10 - path('/.') ok 11 - path('/./') ok 12 - path('/a/./') ok 13 - path('/a/.') ok 14 - path('/../../') ok 15 - path('/../..') ok 16 - path('/t1/t2/t4')->relative('/t1/t2/t3') ok 17 - path('/t1/t2')->relative('/t1/t2/t3') ok 18 - path('/t1/t2/t3/t4')->relative('/t1/t2/t3') ok 19 - path('/t4/t5/t6')->relative('/t1/t2/t3') ok 20 - path('/')->relative('/t1/t2/t3') ok 21 - path('///')->relative('/t1/t2/t3') ok 22 - path('/.')->relative('/t1/t2/t3') ok 23 - path('/./')->relative('/t1/t2/t3') ok 24 - path('/t1/t2/t3')->relative( '/') ok 25 - path('/t1/t2/t3')->relative( '/t1') ok 26 - path('t1/t2/t3')->relative( 't1') ok 27 - path('t1/t2/t3')->relative( 't4') ok 28 - path('.')->relative( '.') ok 29 - path('/')->relative( '/') ok 30 - path('../t1')->relative( 't2/t3') ok 31 - path('t1')->relative( 't2/../t3') ok 32 - path('t4')->absolute('/t1/t2/t3') ok 33 - path('t4/t5')->absolute('/t1/t2/t3') ok 34 - path('.')->absolute('/t1/t2/t3') ok 35 - path('/t1')->absolute('/t1/t2/t3') ok 36 - path('///../../..//./././a//b/.././c/././') ok 37 - path('a/../../b/c') ok 38 - path('..')->absolute('/t1/t2/t3') ok 39 - path('../t4')->absolute('/t1/t2/t3') 1..39 ok All tests successful. Files=18, Tests=357, 7 wallclock secs ( 0.46 usr 0.09 sys + 5.45 cusr 0.64 csys = 6.64 CPU) Result: PASS DAGOLDEN/Path-Tiny-0.032.tar.gz make test TEST_VERBOSE=1 -- OK David Golden <dagolden@cpan.org> File path utility >>> (cd /export/home/fly1432/var/cpan/build/Path-Tiny-0.032-Ul1Y7G && tar cvf - Path-Tiny-0.032.ppd blib) | gzip -c >/export/home/fly1432/var/REPO/D/DA/DAGOLDEN/Path-Tiny-0.032.tar.gz Path-Tiny-0.032.ppd blib/ blib/lib/ blib/lib/Path/ blib/lib/Path/Tiny.pm blib/man3/ blib/man3/Path::Tiny.3 >>> mv /export/home/fly1432/var/cpan/build/Path-Tiny-0.032-Ul1Y7G/Path-Tiny-0.032.ppd /export/home/fly1432/var/REPO/D/DA/DAGOLDEN Finished 2013-09-07T02:29:29