summaryrefslogtreecommitdiffstats
path: root/t
diff options
context:
space:
mode:
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;