summaryrefslogtreecommitdiffstats
path: root/t
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2010-05-11 22:02:16 -0500
committerJesse Luehrs <doy@tozt.net>2010-05-11 22:28:17 -0500
commit56a29840c0b7b0c4a09243ea05400c3df8ad0823 (patch)
treeacfa95e8b9a31f10d7f3d52f0a8b366bca55c637 /t
parent30d1a0987f7c01aad0c45be6b6cf6eada670007a (diff)
downloadpackage-stash-56a29840c0b7b0c4a09243ea05400c3df8ad0823.tar.gz
package-stash-56a29840c0b7b0c4a09243ea05400c3df8ad0823.zip
more support for IO slots
Diffstat (limited to 't')
-rw-r--r--t/001-basic.t18
-rw-r--r--t/003-io.t50
2 files changed, 50 insertions, 18 deletions
diff --git a/t/001-basic.t b/t/001-basic.t
index a3ab29d..52ddfaa 100644
--- a/t/001-basic.t
+++ b/t/001-basic.t
@@ -225,22 +225,4 @@ is($foo_stash->get_package_symbol('@foo'), $ARRAY, '... got the right values for
ok(defined(*{"Foo::foo"}{ARRAY}), '... the @foo slot has NOT been removed');
}
-# check some errors
-
-dies_ok {
- $foo_stash->add_package_symbol('bar');
-} '... no sigil for bar';
-
-dies_ok {
- $foo_stash->remove_package_symbol('bar');
-} '... no sigil for bar';
-
-dies_ok {
- $foo_stash->get_package_symbol('bar');
-} '... no sigil for bar';
-
-dies_ok {
- $foo_stash->has_package_symbol('bar');
-} '... no sigil for bar';
-
done_testing;
diff --git a/t/003-io.t b/t/003-io.t
new file mode 100644
index 0000000..a41b2ae
--- /dev/null
+++ b/t/003-io.t
@@ -0,0 +1,50 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+use Test::Exception;
+
+{
+ package Foo;
+ open *foo, "<", $0;
+
+ sub foo { }
+}
+
+{
+ package Bar;
+ open *bar, "<", $0;
+
+ sub bar { }
+}
+
+use Stash::Manip;
+
+{
+ my $stash = Stash::Manip->new('Foo');
+ ok($stash->has_package_symbol('&foo'), "has &foo");
+ ok($stash->has_package_symbol('foo'), "has foo");
+ $stash->remove_package_symbol('&foo');
+ ok(!$stash->has_package_symbol('&foo'), "has &foo");
+ ok($stash->has_package_symbol('foo'), "has foo");
+}
+
+{
+ my $stash = Stash::Manip->new('Bar');
+ ok($stash->has_package_symbol('&bar'), "has &bar");
+ ok($stash->has_package_symbol('bar'), "has bar");
+ $stash->remove_package_symbol('bar');
+ ok($stash->has_package_symbol('&bar'), "has &bar");
+ ok(!$stash->has_package_symbol('bar'), "has bar");
+}
+
+{
+ my $stash = Stash::Manip->new('Baz');
+ lives_ok {
+ $stash->add_package_symbol('baz', *Foo::foo{IO});
+ } "can add an IO symbol";
+ ok($stash->has_package_symbol('baz'), "has baz");
+ is($stash->get_package_symbol('baz'), *Foo::foo{IO}, "got the right baz");
+}
+
+done_testing;