Squashed commit of the following:
[gitmo/Moose.git] / t / 100_bugs / 012_DEMOLISH_eats_mini.t
index 5773a60..e4b03c4 100644 (file)
@@ -3,11 +3,10 @@
 use strict;
 use warnings;
 
-use Test::More tests => 4;
+use Test::More;
 use Test::Exception;
 
 
-
 {
     package Foo;
     use Moose;
@@ -21,19 +20,19 @@ use Test::Exception;
     # if no call to ANY Moose::Object->new was done before.
     sub DEMOLISH {
         my ( $self ) = @_;
-        # ... Moose (kinda) eats exceptions in DESTROY/DEMOLISH";    
+        # ... Moose (kinda) eats exceptions in DESTROY/DEMOLISH";
     }
 }
 
 {
     my $obj = eval { Foo->new; };
-    ::like( $@, qr/is required/, "... Foo plain" );
-    ::is( $obj, undef, "... the object is undef" );
+    like( $@, qr/is required/, "... Foo plain" );
+    is( $obj, undef, "... the object is undef" );
 }
 
 {
     package Bar;
-    
+
     sub new { die "Bar died"; }
 
     sub DESTROY {
@@ -43,9 +42,60 @@ use Test::Exception;
 
 {
     my $obj = eval { Bar->new; };
-    ::like( $@, qr/Bar died/, "... Bar plain" );
-    ::is( $obj, undef, "... the object is undef" );
+    like( $@, qr/Bar died/, "... Bar plain" );
+    is( $obj, undef, "... the object is undef" );
+}
+
+{
+    package Baz;
+    use Moose;
+
+    sub DEMOLISH {
+        $? = 0;
+    }
+}
+
+{
+    local $@ = 42;
+    local $? = 84;
+
+    {
+        Baz->new;
+    }
+
+    is( $@, 42, '$@ is still 42 after object is demolished without dying' );
+    is( $?, 84, '$? is still 84 after object is demolished without dying' );
+
+    local $@ = 0;
+
+    {
+        Baz->new;
+    }
+
+    is( $@, 0, '$@ is still 0 after object is demolished without dying' );
+
+    Baz->meta->make_immutable, redo
+        if Baz->meta->is_mutable
+}
+
+{
+    package Quux;
+    use Moose;
+
+    sub DEMOLISH {
+        die "foo\n";
+    }
 }
 
-1;
+{
+    local $@ = 42;
+
+    eval { my $obj = Quux->new };
+
+    like( $@, qr/foo/, '$@ contains error from demolish when demolish dies' );
+
+    Quux->meta->make_immutable, redo
+        if Quux->meta->is_mutable
+}
 
+done_testing;