### make sure we can find our conf.pl file BEGIN { use FindBin; require "$FindBin::Bin/inc/conf.pl"; } use strict; use Test::More 'no_plan'; use File::Basename 'dirname'; use Data::Dumper; use CPANPLUS::Error; use CPANPLUS::Internals::Constants; my $conf = gimme_conf(); my $Class = 'CPANPLUS::Backend'; ### D::C has troubles with the 'use_ok' -- it finds the wrong paths. ### for now, do a 'use' instead #use_ok( $Class ) or diag "$Class not found"; use CPANPLUS::Backend; my $cb = $Class->new( $conf ); isa_ok( $cb, $Class ); my $mt = $cb->module_tree; my $at = $cb->author_tree; ok( scalar keys %$mt, "Module tree has entries" ); ok( scalar keys %$at, "Author tree has entries" ); ### module_tree tests ### my $Name = TEST_CONF_MODULE; my $mod = $cb->module_tree($Name); ### XXX SOURCEFILES FIX { my @mods = $cb->module_tree($Name,$Name); my $none = $cb->module_tree( TEST_CONF_INVALID_MODULE ); ok( IS_MODOBJ->(mod => $mod), "Module object found" ); is( scalar(@mods), 2, " Module list found" ); ok( IS_MODOBJ->(mod => $mods[0]), " ISA module object" ); ok( !IS_MODOBJ->(mod => $none), " Bogus module detected"); } ### author_tree tests ### { my @auths = $cb->author_tree( $mod->author->cpanid, $mod->author->cpanid ); my $none = $cb->author_tree( 'fnurk' ); ok( IS_AUTHOBJ->(auth => $mod->author), "Author object found" ); is( scalar(@auths), 2, " Author list found" ); ok( IS_AUTHOBJ->( author => $auths[0] )," ISA author object" ); is( $mod->author, $auths[0], " Objects are identical" ); ok( !IS_AUTHOBJ->( author => $none ), " Bogus author detected" ); } my $conf_obj = $cb->configure_object; ok( IS_CONFOBJ->(conf => $conf_obj), "Configure object found" ); ### parse_module tests ### { my @map = ( $Name => [ $mod->author->cpanid, # author $mod->package_name, # package name $mod->version, # version ], $mod => [ $mod->author->cpanid, $mod->package_name, $mod->version, ], 'Foo-Bar-EU-NOXS' => [ $mod->author->cpanid, $mod->package_name, $mod->version, ], 'Foo-Bar-EU-NOXS-0.01' => [ $mod->author->cpanid, $mod->package_name, '0.01', ], 'EUNOXS/Foo-Bar-EU-NOXS' => [ 'EUNOXS', $mod->package_name, $mod->version, ], 'EUNOXS/Foo-Bar-EU-NOXS-0.01' => [ 'EUNOXS', $mod->package_name, '0.01', ], ### existing module, no extension given ### this used to create a modobj with no package extension 'EUNOXS/Foo-Bar-0.02' => [ 'EUNOXS', 'Foo-Bar', '0.02', ], 'Foo-Bar-EU-NOXS-0.09' => [ $mod->author->cpanid, $mod->package_name, '0.09', ], 'MBXS/Foo-Bar-EU-NOXS-0.01' => [ 'MBXS', $mod->package_name, '0.01', ], 'EUNOXS/Foo-Bar-EU-NOXS-0.09' => [ 'EUNOXS', $mod->package_name, '0.09', ], 'EUNOXS/Foo-Bar-EU-NOXS-0.09.zip' => [ 'EUNOXS', $mod->package_name, '0.09', ], 'FROO/Flub-Flob-1.1.zip' => [ 'FROO', 'Flub-Flob', '1.1', ], 'G/GO/GOYALI/SMS_API_3_01.tar.gz' => [ 'GOYALI', 'SMS_API', '3_01', ], 'E/EY/EYCK/Net/Lite/Net-Lite-FTP-0.091' => [ 'EYCK', 'Net-Lite-FTP', '0.091', ], 'EYCK/Net/Lite/Net-Lite-FTP-0.091' => [ 'EYCK', 'Net-Lite-FTP', '0.091', ], 'M/MA/MAXDB/DBD-MaxDB-7.5.0.24a' => [ 'MAXDB', 'DBD-MaxDB', '7.5.0.24a', ], 'EUNOXS/perl5.005_03.tar.gz' => [ 'EUNOXS', 'perl', '5.005_03', ], 'FROO/Flub-Flub-v1.1.0.tbz' => [ 'FROO', 'Flub-Flub', 'v1.1.0', ], 'FROO/Flub-Flub-1.1_2.tbz' => [ 'FROO', 'Flub-Flub', '1.1_2', ], 'LDS/CGI.pm-3.27.tar.gz' => [ 'LDS', 'CGI', '3.27', ], 'FROO/Text-Tabs+Wrap-2006.1117.tar.gz' => [ 'FROO', 'Text-Tabs+Wrap', '2006.1117', ], 'JETTERO/Crypt-PBC-0.7.20.0-0.4.9' => [ 'JETTERO', 'Crypt-PBC', '0.7.20.0-0.4.9' , ], 'GRICHTER/HTML-Embperl-1.2.1.tar.gz' => [ 'GRICHTER', 'HTML-Embperl', '1.2.1', ], 'KANE/File-Fetch-0.15_03' => [ 'KANE', 'File-Fetch', '0.15_03', ], 'AUSCHUTZ/IO-Stty-.02.tar.gz' => [ 'AUSCHUTZ', 'IO-Stty', '.02', ], '.' => [ 'CPANPLUS', 't', '', ], 'Foo/Bar.pm' => [ $mod->author->cpanid, # author $mod->package_name, # package name $mod->version, # version ], ); while ( my($guess, $attr) = splice @map, 0, 2 ) { my( $author, $pkg_name, $version ) = @$attr; ok( $guess, "Attempting to parse $guess" ); my $obj = $cb->parse_module( module => $guess ); ok( $obj, " Result returned" ); ok( IS_MODOBJ->( mod => $obj ), " parse_module success by '$guess'" ); is( $obj->version, $version, " Proper version found: $version" ); is( $obj->package_version, $version, " Found in package_version as well" ); ### VMS doesn't preserve case, so match them after normalizing case is( uc($obj->package_name), uc($pkg_name), " Proper package_name found: $pkg_name" ); unlike( $obj->package_name, qr/\d/, " No digits in package name" ); { my $ext = $obj->package_extension; ok( $ext, " Has extension as well: $ext" ); } like( $obj->author->cpanid, "/$author/i", " Proper author found: $author"); like( $obj->path, "/$author/i", " Proper path found: " . $obj->path ); } ### test for things that look like real modules, but aren't ### { my @map = ( [ $Name . $$ => [ [qr/does not contain an author/,"Missing author part detected"], [qr/Cannot find .+? in the module tree/,"Unable to find module"] ] ], [ {}, => [ [ qr/module string from reference/,"Unable to parse ref"] ] ], ); for my $entry ( @map ) { my($mod,$aref) = @$entry; my $none = $cb->parse_module( module => $mod ); ok( !IS_MODOBJ->(mod => $none), "Non-existent module detected" ); ok( !IS_FAKE_MODOBJ->(mod => $none), "Non-existent fake module detected" ); my $str = CPANPLUS::Error->stack_as_string; for my $pair (@$aref) { my($re,$diag) = @$pair; like( $str, $re," $diag" ); } } } ### test parsing of arbitrary URI for my $guess ( qw[ http://foo/bar.gz http://a/b/c/d/e/f/g/h/i/j flub://floo ] ) { my $obj = $cb->parse_module( module => $guess ); ok( IS_FAKE_MODOBJ->(mod => $obj), "parse_module success by '$guess'" ); is( $obj->status->_fetch_from, $guess, " Fetch from set ok" ); } } ### RV tests ### { my $method = 'readme'; my %args = ( modules => [$Name] ); my $rv = $cb->$method( %args ); ok( IS_RVOBJ->( $rv ), "Got an RV object" ); ok( $rv->ok, " Overall OK" ); cmp_ok( $rv, '==', 1, " Overload OK" ); is( $rv->function, $method, " Function stored OK" ); is_deeply( $rv->args, \%args, " Arguments stored OK" ); is( $rv->rv->{$Name}, $mod->readme, " RV as expected" ); } ### reload_indices tests ### { my $file = File::Spec->catfile( $conf->get_conf('base'), $conf->_get_source('mod'), ); ok( $cb->reload_indices( update_source => 0 ), "Rebuilding trees" ); my $age = -M $file; ### make sure we are 'newer' on faster machines with a sleep.. ### apparently Win32's FAT isn't granual enough on intervals ### < 2 seconds, so it may give the same answer before and after ### the sleep, causing the test to fail. so sleep atleast 2 seconds. sleep 2; ok( $cb->reload_indices( update_source => 1 ), "Rebuilding and refetching trees" ); cmp_ok( $age, '>', -M $file, " Source file '$file' updated" ); } ### flush tests ### { for my $cache( qw[methods hosts modules lib all] ) { ok( $cb->flush($cache), "Cache $cache flushed ok" ); } } ### installed tests ### { ok( scalar($cb->installed), "Found list of installed modules" ); } ### autobudle tests ### { my $where = $cb->autobundle; ok( $where, "Autobundle written" ); ok( -s $where, " File has size" ); } ### local_mirror tests ### { ### turn off md5 checks for the 'fake' packages we have my $old_md5 = $conf->get_conf('md5'); $conf->set_conf( md5 => 0 ); ### otherwise 'status->fetch' might be undef! ### my $rv = $cb->local_mirror( path => 'dummy-localmirror' ); ok( $rv, "Local mirror created" ); for my $mod ( values %{ $cb->module_tree } ) { my $name = $mod->module; my $cksum = File::Spec->catfile( dirname($mod->status->fetch), CHECKSUMS ); ok( -e $mod->status->fetch, " Module '$name' fetched" ); ok( -s _, " Module '$name' has size" ); ok( -e $cksum, " Checksum fetched for '$name'" ); ok( -s _, " Checksum for '$name' has size" ); } $conf->set_conf( md5 => $old_md5 ); } ### check ENV variable { ### process id { my $name = 'PERL5_CPANPLUS_IS_RUNNING'; ok( $ENV{$name}, "Env var '$name' set" ); is( $ENV{$name}, $$, " Set to current process id" ); } ### Version { my $name = 'PERL5_CPANPLUS_IS_VERSION'; ok( $ENV{$name}, "Env var '$name' set" ); ### version.pm formats ->VERSION output... *sigh* is( $ENV{$name}, $Class->VERSION, " Set to current process version" ); } } __END__ # Local variables: # c-indentation-style: bsd # c-basic-offset: 4 # indent-tabs-mode: nil # End: # vim: expandtab shiftwidth=4: