6 use Test::More tests => 25;
8 use Bit::MorseSignals::Emitter;
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');
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');
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');
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");
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');