+ my @warns;
+ {
+ local $SIG{__WARN__} = sub { push @warns, "@_" };
+ eval <<' HERE';
+ return;
+ no indirect;
+ my $x = new Warn1;
+ $x = new Warn2;
+ HERE
+ }
+ my $w1 = shift @warns;
+ my $w2 = shift @warns;
+ is $@, '', 'didn\'t croak without arguments';
+ like $w1, expect('Warn1'), 'first warning caught without arguments';
+ like $w2, expect('Warn2'), 'second warning caught without arguments';
+ is_deeply \@warns, [ ], 'no more warnings without arguments';
+}
+
+for my $fatal (':fatal', 'FATAL', ':Fatal') {
+ {
+ local $SIG{__WARN__} = sub { die "warn:@_" };
+ eval <<" HERE";
+ die qq{shouldn't even compile\n};
+ no indirect '$fatal';
+ my \$x = new Croaked;
+ \$x = new NotReached;
+ HERE
+ }
+ like $@, expect('Croaked'), "croaks when $fatal is specified";
+}
+
+{
+ {
+ local $SIG{__WARN__} = sub { "warn:@_" };
+ eval <<' HERE';
+ die qq{shouldn't even compile\n};
+ no indirect 'whatever', hook => sub { die 'hook:' . join(':', @_) . "\n" };
+ my $x = new Hooked;
+ $x = new AlsoNotReached;
+ HERE
+ }
+ like $@, qr/^hook:Hooked:new:\(eval\s+\d+\):\d+$/, 'calls the specified hook';
+}
+
+{
+ my $no_hook_and_fatal = qr/^The 'fatal' and 'hook' options are mutually exclusive at \(eval \d+\) line \d+/;
+
+ {
+ local $SIG{__WARN__} = sub { die "warn:@_" };
+ eval <<' HERE';
+ die qq{shouldn't even compile\n};
+ no indirect 'fatal', hook => sub { };
+ new NotReached;
+ HERE
+ }
+ like $@, $no_hook_and_fatal, '"no indirect qw<fatal hook>" croaks';
+
+ {
+ local $SIG{__WARN__} = sub { die "warn:@_" };
+ eval <<' HERE';
+ die qq{shouldn't even compile\n};
+ no indirect hook => sub { }, 'fatal';
+ new NotReached;
+ HERE
+ }
+ like $@, $no_hook_and_fatal, '"no indirect qw<hook fatal>" croaks';