X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=t%2Fimpl-selection%2Fbasic-xs.t;h=8a1b40b10f88ddd61f6deb3f7e830ab5ef1d1e23;hb=abe3605b9e63d97458ea495347501b5696ec2bc8;hp=0fe2aa35ce6ea3be42d7fa8c6a99f9b69231d4f6;hpb=0f40e41f356af017fc3ff3a2c685c61ff648b4c0;p=gitmo%2FPackage-Stash.git diff --git a/t/impl-selection/basic-xs.t b/t/impl-selection/basic-xs.t index 0fe2aa3..8a1b40b 100644 --- a/t/impl-selection/basic-xs.t +++ b/t/impl-selection/basic-xs.t @@ -257,6 +257,8 @@ is($foo_stash->get_symbol('@foo'), $ARRAY, '... got the right values for @Foo::f { $foo_stash->add_symbol('%zork'); + ok(!$foo_stash->has_symbol('$zork'), + "add_symbol with single argument doesn't vivify scalar slot"); my $syms = $foo_stash->get_all_symbols('HASH'); @@ -422,4 +424,24 @@ like(exception { ); } +for my $package ('Foo:Bar', 'Foo/Bar', 'Foo Bar', 'Foo:::Bar', '') { + like( + exception { Package::Stash->new($package) }, + qr/^$package is not a module name/, + "$package is not a module name" + ); +} + +like( + exception { Package::Stash->new([]) }, + qr/^Package::Stash->new must be passed the name of the package to access/, + "module name must be a string" +); + +like( + exception { Package::Stash->new(undef) }, + qr/^Package::Stash->new must be passed the name of the package to access/, + "module name must be a string" +); + done_testing;