summaryrefslogtreecommitdiffstats
path: root/t/20-leaks.t
diff options
context:
space:
mode:
authorJesse Luehrs <doy@tozt.net>2010-11-13 09:38:09 -0600
committerJesse Luehrs <doy@tozt.net>2010-11-13 09:38:09 -0600
commit58710c0b0c0d861abfef51f0d8b35761035c4f4b (patch)
tree10bc9dce5de8dc6977d8d3755a7561a7221425a9 /t/20-leaks.t
parentce38493ccaffb0867e6d891b041a03de0feb97a7 (diff)
downloadpackage-stash-xs-58710c0b0c0d861abfef51f0d8b35761035c4f4b.tar.gz
package-stash-xs-58710c0b0c0d861abfef51f0d8b35761035c4f4b.zip
add leak test
Diffstat (limited to 't/20-leaks.t')
-rw-r--r--t/20-leaks.t143
1 files changed, 143 insertions, 0 deletions
diff --git a/t/20-leaks.t b/t/20-leaks.t
new file mode 100644
index 0000000..124e49e
--- /dev/null
+++ b/t/20-leaks.t
@@ -0,0 +1,143 @@
+#!/usr/bin/env perl
+use strict;
+use warnings;
+use Test::More;
+use Test::Fatal;
+use Test::Requires 'Test::LeakTrace';
+
+use Package::Stash;
+use Symbol;
+
+{
+ package Bar;
+}
+
+{
+ package Baz;
+ our $foo;
+ sub bar { }
+ use constant baz => 1;
+ our %quux = (a => 'b');
+}
+
+{
+ no_leaks_ok {
+ Package::Stash->new('Foo');
+ } "object construction doesn't leak";
+}
+
+{
+ no_leaks_ok {
+ Package::Stash->new('Bar');
+ } "object construction doesn't leak, with an existing package";
+}
+
+{
+ no_leaks_ok {
+ Package::Stash->new('Baz');
+ } "object construction doesn't leak, with an existing package with things in it";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ no_leaks_ok {
+ $foo->name;
+ $foo->namespace;
+ } "accessors don't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ leaks_cmp_ok {
+ $foo->add_package_symbol('$scalar');
+ $foo->add_package_symbol('@array');
+ $foo->add_package_symbol('%hash');
+ $foo->add_package_symbol('io');
+ } '==', 4, "add_package_symbol doesn't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ leaks_cmp_ok {
+ $foo->add_package_symbol('$scalar_init' => 1);
+ $foo->add_package_symbol('@array_init' => []);
+ $foo->add_package_symbol('%hash_init' => {});
+ # hmmm, wonder why this coderef isn't treated as a leak
+ $foo->add_package_symbol('&code_init' => sub { "foo" });
+ $foo->add_package_symbol('io_init' => Symbol::geniosym);
+ } '==', 9, "add_package_symbol doesn't leak";
+ is(exception {
+ is(Foo->code_init, 'foo', "sub installed correctly")
+ }, undef, "code_init exists");
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ no_leaks_ok {
+ $foo->remove_package_symbol('$scalar_init');
+ $foo->remove_package_symbol('@array_init');
+ $foo->remove_package_symbol('%hash_init');
+ $foo->remove_package_symbol('&code_init');
+ $foo->remove_package_symbol('io_init');
+ } "remove_package_symbol doesn't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ $foo->add_package_symbol("${_}glob") for ('$', '@', '%', '&', '');
+ no_leaks_ok {
+ $foo->remove_package_glob('glob');
+ } "remove_package_glob doesn't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ no_leaks_ok {
+ $foo->has_package_symbol('io');
+ $foo->has_package_symbol('%hash');
+ $foo->has_package_symbol('@array_init');
+ $foo->has_package_symbol('$glob');
+ $foo->has_package_symbol('&something_else');
+ } "has_package_symbol doesn't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ no_leaks_ok {
+ $foo->get_package_symbol('io');
+ $foo->get_package_symbol('%hash');
+ $foo->get_package_symbol('@array_init');
+ $foo->get_package_symbol('$glob');
+ $foo->get_package_symbol('&something_else');
+ } "get_package_symbol doesn't leak";
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ ok(!$foo->has_package_symbol('$glob'));
+ ok(!$foo->has_package_symbol('@array_init'));
+ no_leaks_ok {
+ $foo->get_or_add_package_symbol('io');
+ $foo->get_or_add_package_symbol('%hash');
+ # and why are these not leaks either?
+ $foo->get_or_add_package_symbol('@array_init');
+ $foo->get_or_add_package_symbol('$glob');
+ } "get_or_add_package_symbol doesn't leak";
+ ok($foo->has_package_symbol('$glob'));
+ is(ref($foo->get_package_symbol('$glob')), 'SCALAR');
+ ok($foo->has_package_symbol('@array_init'));
+ is(ref($foo->get_package_symbol('@array_init')), 'ARRAY');
+}
+
+{
+ my $foo = Package::Stash->new('Foo');
+ my $baz = Package::Stash->new('Baz');
+ no_leaks_ok {
+ $foo->list_all_package_symbols;
+ $foo->list_all_package_symbols('SCALAR');
+ $foo->list_all_package_symbols('CODE');
+ $baz->list_all_package_symbols('CODE');
+ } "list_all_package_symbols doesn't leak";
+}
+
+done_testing;