r11693@rob-kinyons-powerbook58: rob | 2006-04-30 22:15:38 -0400
[dbsrgits/DBM-Deep.git] / t / 21_tie_access.t
index f8eae18..29a5ef6 100644 (file)
@@ -2,20 +2,17 @@
 # DBM::Deep Test
 ##
 use strict;
-use Test::More;
+use Test::More tests => 7;
 use Test::Exception;
-
-plan tests => 7;
+use t::common qw( new_fh );
 
 use_ok( 'DBM::Deep' );
 
-# How should one test for creation failure with the tie mechanism?
-
-unlink "t/test.db";
+my ($fh, $filename) = new_fh();
 
 {
     my %hash;
-    tie %hash, 'DBM::Deep', "t/test.db";
+    tie %hash, 'DBM::Deep', $filename;
 
     $hash{key1} = 'value';
     is( $hash{key1}, 'value', 'Set and retrieved key1' );
@@ -23,7 +20,7 @@ unlink "t/test.db";
 
 {
     my %hash;
-    tie %hash, 'DBM::Deep', "t/test.db";
+    tie %hash, 'DBM::Deep', $filename;
 
     is( $hash{key1}, 'value', 'Set and retrieved key1' );
 
@@ -31,19 +28,23 @@ unlink "t/test.db";
     ok( exists $hash{key1}, "... and it's key1" );
 }
 
-throws_ok {
-    tie my @array, 'DBM::Deep', {
-        file => 't/test.db',
-        type => DBM::Deep->TYPE_ARRAY,
-    };
-} qr/DBM::Deep: File type mismatch/, "\$SIG_TYPE doesn't match file's type";
-
-unlink "t/test2.db";
-DBM::Deep->new( file => 't/test2.db', type => DBM::Deep->TYPE_ARRAY );
-
-throws_ok {
-    tie my %hash, 'DBM::Deep', {
-        file => 't/test2.db',
-        type => DBM::Deep->TYPE_HASH,
-    };
-} qr/DBM::Deep: File type mismatch/, "\$SIG_TYPE doesn't match file's type";
+{
+    throws_ok {
+        tie my @array, 'DBM::Deep', {
+            file => $filename,
+            type => DBM::Deep->TYPE_ARRAY,
+        };
+    } qr/DBM::Deep: File type mismatch/, "\$SIG_TYPE doesn't match file's type";
+}
+
+{
+    my ($fh, $filename) = new_fh();
+    DBM::Deep->new( file => $filename, type => DBM::Deep->TYPE_ARRAY );
+
+    throws_ok {
+        tie my %hash, 'DBM::Deep', {
+            file => $filename,
+            type => DBM::Deep->TYPE_HASH,
+        };
+    } qr/DBM::Deep: File type mismatch/, "\$SIG_TYPE doesn't match file's type";
+}