summaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorchromatic <chromatic@wgz.org>2001-09-28 15:20:12 -0600
committerJarkko Hietaniemi <jhi@iki.fi>2001-09-29 13:49:43 +0000
commitc6c73c786b4d4a71e6f053b58104cf6488c744a4 (patch)
treeef24bea7e5a9ee87fed78d86afa86f778d365df8 /lib
parentd9efae67d76cc4acd8980b711b5bebc7142b5319 (diff)
downloadperl-c6c73c786b4d4a71e6f053b58104cf6488c744a4.tar.gz
Add tests, clean up Tie::Scalar
Message-ID: <20010929032543.58322.qmail@onion.perl.org> p4raw-id: //depot/perl@12265
Diffstat (limited to 'lib')
-rw-r--r--lib/Tie/Scalar.pm2
-rw-r--r--lib/Tie/Scalar.t76
2 files changed, 77 insertions, 1 deletions
diff --git a/lib/Tie/Scalar.pm b/lib/Tie/Scalar.pm
index bcaad0b11e..c23c12187a 100644
--- a/lib/Tie/Scalar.pm
+++ b/lib/Tie/Scalar.pm
@@ -92,7 +92,7 @@ sub new {
sub TIESCALAR {
my $pkg = shift;
- if (defined &{"{$pkg}::new"}) {
+ if ($pkg->can('new') and $pkg ne __PACKAGE__) {
warnings::warnif("WARNING: calling ${pkg}->new since ${pkg}->TIESCALAR is missing");
$pkg->new(@_);
}
diff --git a/lib/Tie/Scalar.t b/lib/Tie/Scalar.t
new file mode 100644
index 0000000000..3c5d9b6146
--- /dev/null
+++ b/lib/Tie/Scalar.t
@@ -0,0 +1,76 @@
+#!./perl
+
+BEGIN {
+ chdir 't' if -d 't';
+ @INC = '../lib';
+}
+
+# this must come before main, or tests will fail
+package TieTest;
+
+use Tie::Scalar;
+use vars qw( @ISA );
+@ISA = qw( Tie::Scalar );
+
+sub new { 'Fooled you.' }
+
+package main;
+
+use vars qw( $flag );
+use Test::More tests => 13;
+
+use_ok( 'Tie::Scalar' );
+
+# these are "abstract virtual" parent methods
+for my $method qw( TIESCALAR FETCH STORE ) {
+ eval { Tie::Scalar->$method() };
+ like( $@, qr/doesn't define a $method/, "croaks on inherited $method()" );
+}
+
+# the default value is undef
+my $scalar = Tie::StdScalar->TIESCALAR();
+is( $$scalar, undef, 'used TIESCALAR, default value is still undef' );
+
+# Tie::StdScalar redirects to TIESCALAR
+$scalar = Tie::StdScalar->new();
+is( $$scalar, undef, 'used new(), default value is still undef' );
+
+# this approach should work as well
+tie $scalar, 'Tie::StdScalar';
+is( $$scalar, undef, 'tied a scalar, default value is undef' );
+
+# first set, then read
+$scalar = 'fetch me';
+is( $scalar, 'fetch me', 'STORE() and FETCH() verified with one test!' );
+
+# test DESTROY with an object that signals its destruction
+{
+ my $scalar = 'foo';
+ tie $scalar, 'Tie::StdScalar', DestroyAction->new();
+ ok( $scalar, 'tied once more' );
+ is( $flag, undef, 'destroy flag not set' );
+}
+
+# $scalar out of scope, Tie::StdScalar::DESTROY() called, DestroyAction set flag
+is( $flag, 1, 'and DESTROY() works' );
+
+# we want some noise, and some way to capture it
+use warnings;
+my $warn;
+local $SIG{__WARN__} = sub {
+ $warn = $_[0];
+};
+
+# Tie::Scalar::TIEHANDLE should find and call TieTest::new and complain
+is( tie( my $foo, 'TieTest'), 'Fooled you.', 'delegated to new()' );
+like( $warn, qr/WARNING: calling TieTest->new/, 'caught warning fine' );
+
+package DestroyAction;
+
+sub new {
+ bless( \(my $self), $_[0] );
+}
+
+sub DESTROY {
+ $main::flag = 1;
+}