X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?p=catagits%2FCatalyst-Runtime.git;a=blobdiff_plain;f=t%2Funit_utils_load_class.t;h=510d9c164262f4946f33d4cd755270613948e80c;hp=cddc400bb75fe7806fa0b18be05e423ab243ee78;hb=33d3ae66457093bf400181b1a8145460257fc563;hpb=d9183506af8ce9cd1339fceb19d941f293efb17b diff --git a/t/unit_utils_load_class.t b/t/unit_utils_load_class.t index cddc400..510d9c1 100644 --- a/t/unit_utils_load_class.t +++ b/t/unit_utils_load_class.t @@ -1,13 +1,17 @@ -#!/usr/bin/perl - use strict; use warnings; -use Test::More tests => 12; - +use Test::More; +use Class::Load 'is_class_loaded'; use lib "t/lib"; -BEGIN { use_ok("Catalyst::Utils") }; +BEGIN { + if ($^O =~ m/^MSWin/) { + plan skip_all => 'Skipping this test on Windows until someone with Windows has time to fix it'; + } + + use_ok("Catalyst::Utils"); +} { package This::Module::Is::Not::In::Inc::But::Does::Exist; @@ -15,13 +19,16 @@ BEGIN { use_ok("Catalyst::Utils") }; } my $warnings = 0; -$SIG{__WARN__} = sub { $warnings++ }; +$SIG{__WARN__} = sub { + return if $_[0] =~ /Subroutine (?:un|re|)initialize redefined at .*C3\.pm/; + $warnings++; +}; -ok( !Class::Inspector->loaded("TestApp::View::Dump"), "component not yet loaded" ); +ok( !is_class_loaded("TestApp::View::Dump"), "component not yet loaded" ); Catalyst::Utils::ensure_class_loaded("TestApp::View::Dump"); -ok( Class::Inspector->loaded("TestApp::View::Dump"), "loaded ok" ); +ok( is_class_loaded("TestApp::View::Dump"), "loaded ok" ); is( $warnings, 0, "no warnings emitted" ); $warnings = 0; @@ -29,10 +36,10 @@ $warnings = 0; Catalyst::Utils::ensure_class_loaded("TestApp::View::Dump"); is( $warnings, 0, "calling again doesn't reaload" ); -ok( !Class::Inspector->loaded("TestApp::View::Dump::Request"), "component not yet loaded" ); +ok( !is_class_loaded("TestApp::View::Dump::Request"), "component not yet loaded" ); Catalyst::Utils::ensure_class_loaded("TestApp::View::Dump::Request"); -ok( Class::Inspector->loaded("TestApp::View::Dump::Request"), "loaded ok" ); +ok( is_class_loaded("TestApp::View::Dump::Request"), "loaded ok" ); is( $warnings, 0, "calling again doesn't reaload" ); @@ -41,6 +48,11 @@ eval { Catalyst::Utils::ensure_class_loaded("This::Module::Is::Probably::Not::Th ok( $@, "doesn't defatalize" ); like( $@, qr/There\.pm.*\@INC/, "error looks right" ); +undef $@; +eval { Catalyst::Utils::ensure_class_loaded("__PACKAGE__") }; +ok( $@, "doesn't defatalize" ); +like( $@, qr/__PACKAGE__\.pm.*\@INC/, "errors sanely on __PACKAGE__.pm" ); + $@ = "foo"; Catalyst::Utils::ensure_class_loaded("TestApp::View::Dump::Response"); is( $@, "foo", '$@ is untouched' ); @@ -49,3 +61,18 @@ undef $@; eval { Catalyst::Utils::ensure_class_loaded("This::Module::Is::Not::In::Inc::But::Does::Exist") }; ok( !$@, "no error when loading non existent .pm that *does* have a symbol table entry" ); +undef $@; +eval { Catalyst::Utils::ensure_class_loaded('Silly::File::.#Name') }; +like($@, qr/Malformed class Name/, 'errored when attempting to load a file beginning with a .'); + +undef $@; +eval { Catalyst::Utils::ensure_class_loaded('Silly::File::Name.pm') }; +like($@, qr/Malformed class Name/, 'errored sanely when given a classname ending in .pm'); + +undef $@; +$warnings = 0; +Catalyst::Utils::ensure_class_loaded("NullPackage"); +is( $warnings, 1, 'Loading a package which defines no symbols warns'); +is( $@, undef, '$@ still undef' ); + +done_testing;