]> git.vpit.fr Git - perl/modules/Bit-MorseSignals.git/blob - t/20-emitter-obj.t
Switch to qw<>
[perl/modules/Bit-MorseSignals.git] / t / 20-emitter-obj.t
1 #!perl -T
2
3 use strict;
4 use warnings;
5
6 use Test::More tests => 25;
7
8 use Bit::MorseSignals::Emitter;
9
10 my $deuce = Bit::MorseSignals::Emitter->new;
11 ok(defined $deuce, 'BME object is defined');
12 is(ref $deuce, 'Bit::MorseSignals::Emitter', 'BME object is valid');
13
14 my $deuce2 = $deuce->new;
15 ok(defined $deuce2, 'BME::new called as an object method works' );
16 is(ref $deuce2, 'Bit::MorseSignals::Emitter', 'BME::new called as an object method works is valid');
17 ok(!defined Bit::MorseSignals::Emitter::new(), 'BME::new called without a class is invalid');
18
19 eval { $deuce2 = Bit::MorseSignals::Emitter->new(qw<a b c>) };
20 like($@, qr/Optional\s+arguments/, 'BME::new gets parameters as key => value pairs');
21
22 my $fake = { };
23 bless $fake, 'Bit::MorseSignal::Hlagh';
24 for (qw<post pop len pos reset flush busy queued>) {
25  eval "Bit::MorseSignals::Emitter::$_('Bit::MorseSignals::Emitter')";
26  like($@, qr/^First\s+argument/, "BME::$_ isn't a class method");
27  eval "Bit::MorseSignals::Emitter::$_(\$fake)";
28  like($@, qr/^First\s+argument/, "BME::$_ only applies to BME objects");
29 }
30
31 eval { $deuce->post('foo', qw<a b c>) };
32 like($@, qr/Optional\s+arguments/, 'BME::post gets parameters after the first as key => value pairs');
33 ok(!defined($deuce->post(sub { 1 })), 'BME::post doesn\'t take CODE references');
34 ok(!defined($deuce->post(\*STDERR)), 'BME::post doesn\'t take GLOB references');