From c6ddb1d1e19b3e23d64840dd62e2f9c777b5eb09 Mon Sep 17 00:00:00 2001 From: Jesse Luehrs Date: Tue, 29 Nov 2011 14:27:30 -0600 Subject: add some tests for bare anon stashes --- t/bare-anon.t | 63 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 t/bare-anon.t (limited to 't/bare-anon.t') diff --git a/t/bare-anon.t b/t/bare-anon.t new file mode 100644 index 0000000..3c96ec8 --- /dev/null +++ b/t/bare-anon.t @@ -0,0 +1,63 @@ +#!/usr/bin/env perl +use strict; +use warnings; +use Test::More; +use Test::Fatal; +use lib 't/lib'; + +use Package::Stash; +use Symbol; + +plan skip_all => "Anonymous stashes in PP need at least perl 5.14" + if Package::Stash::BROKEN_GLOB_ASSIGNMENT; + +my $anon = {}; +my $stash = Package::Stash->new($anon); +# no way to bless something into a hashref yet +# my $obj = $anon->bless({}); + +{ + my $code = sub { 'FOO' }; + $stash->add_symbol('&foo' => $code); + is($stash->get_symbol('&foo'), $code); + # is($obj->foo, 'FOO'); +} + +{ + local $TODO = ($Package::Stash::IMPLEMENTATION eq 'PP') + ? "can't inflate weird stash entries" + : undef; + $anon->{bar} = \123; + + is( + exception { + my $code = $stash->get_symbol('&bar'); + is(ref($code), 'CODE'); + is($code->(), 123); + + # is($obj->bar, 123); + }, + undef + ); +} + +{ + local $TODO = ($Package::Stash::IMPLEMENTATION eq 'PP') + ? "can't inflate weird stash entries" + : undef; + $anon->{baz} = -1; + + is( + exception { + my $code = $stash->get_symbol('&baz'); + is(ref($code), 'CODE'); + like( + exception { $code->() }, + qr/Undefined subroutine \&__ANON__::baz called/ + ); + }, + undef + ); +} + +done_testing; -- cgit v1.2.3-54-g00ecf