diff options
author | chromatic <chromatic@wgz.org> | 2001-09-28 11:39:50 -0600 |
---|---|---|
committer | Jarkko Hietaniemi <jhi@iki.fi> | 2001-09-28 23:04:13 +0000 |
commit | dec75bd425a450bfb45a3bf9ad7cab6c16035737 (patch) | |
tree | 4bc1f59a159764516b924a771d5b1004ad956701 /lib/open.t | |
parent | 546e4b85ba4cb8fd28da2519546d499dbd3c2ec1 (diff) | |
download | perl-dec75bd425a450bfb45a3bf9ad7cab6c16035737.tar.gz |
Add tests for open.pm
Message-ID: <20010928234521.14178.qmail@onion.perl.org>
p4raw-id: //depot/perl@12263
Diffstat (limited to 'lib/open.t')
-rw-r--r-- | lib/open.t | 68 |
1 files changed, 68 insertions, 0 deletions
diff --git a/lib/open.t b/lib/open.t new file mode 100644 index 0000000000..90e5e3b448 --- /dev/null +++ b/lib/open.t @@ -0,0 +1,68 @@ +#!./perl + +BEGIN { + chdir 't' if -d 't'; + @INC = '../lib'; +} + +use Test::More tests => 12; + +# open::import expects 'open' as its first argument, but it clashes with open() +sub import { + open::import( 'open', @_ ); +} + +# can't use require_ok() here, with a name like 'open' +ok( require 'open.pm', 'required okay!' ); + +# this should fail +eval { import() }; +like( $@, qr/needs explicit list of disciplines/, 'import fails without args' ); + +# the hint bits shouldn't be set yet +is( $^H & $open::hint_bits, 0, '$^H is okay before open import runs' ); + +# prevent it from loading I18N::Langinfo, so we can test encoding failures +local @INC; +$ENV{LC_ALL} = ''; +eval { import( 'IN', 'locale' ) }; +like( $@, qr/Cannot figure out an encoding/, 'no encoding found' ); + +my $warn; +local $SIG{__WARN__} = sub { + $warn .= shift; +}; + +# and it shouldn't be able to find this discipline +eval{ import( 'IN', 'macguffin' ) }; +like( $warn, qr/Unknown discipline layer/, 'warned about unknown discipline' ); + +# now load a real-looking locale +$ENV{LC_ALL} = ' .utf8'; +import( 'IN', 'locale' ); +is( ${^OPEN}, ':utf8\0', 'set locale layer okay!' ); + +# and see if it sets the magic variables appropriately +import( 'IN', ':crlf' ); +ok( $^H & $open::hint_bits, '$^H is set after open import runs' ); +is( $^H{'open_IN'}, 'crlf', 'set crlf layer okay!' ); + +# it should reset them appropriately, too +import( 'IN', ':raw' ); +is( $^H{'open_IN'}, 'raw', 'set raw layer okay!' ); + +# it dies if you don't set IN, OUT, or INOUT +eval { import( 'sideways', ':raw' ) }; +like( $@, qr/Unknown discipline class/, 'croaked with unknown class' ); + +# but it handles them all so well together +import( 'INOUT', ':raw :crlf' ); +is( ${^OPEN}, ':raw :crlf\0:raw :crlf', 'multi types, multi disciplines' ); +is( $^H{'open_INOUT'}, 'crlf', 'last layer set in %^H' ); + +__END__ +# this one won't run as $locale_encoding is already set +# perhaps qx{} it, if it's important to run +$ENV{LC_ALL} = 'nonexistent.euc'; +eval { open::_get_locale_encoding() }; +like( $@, qr/too ambiguous/, 'died with ambiguous locale encoding' ); |