このテスト スクリプトを実行しました。
use strict;
use warnings;
use Test::More tests => 3;
use Carp;
ok(1<2);
pass();
fail();
croak "example";
コマンドラインを使用するprove -MCarp=verbose -v foo.pl
と、次のエラーが発生しました。
Subroutine App::Prove::verbose redefined at /opt/ActivePerl-5.12/lib/App/Prove.pm line 407
App::Prove::_load_extension('App::Prove=HASH(0x683718)', 'Carp=verbose') called at /opt/ActivePerl-5.12/lib/App/Prove.pm line 419
App::Prove::_load_extensions('App::Prove=HASH(0x683718)', 'ARRAY(0x683850)') called at /opt/ActivePerl-5.12/lib/App/Prove.pm line 481
App::Prove::run('App::Prove=HASH(0x683718)') called at /opt/ActivePerl-5.12/bin/prove line 11
Undefined subroutine &Carp::verbose called at /opt/ActivePerl-5.12/lib/App/Prove.pm line 484.
を使用して実行してperl -MCarp=verbose foo.pl
も問題ありません。prove
詳細なCarpを拒否する原因は何ですか? croak
にグローバルに置き換えcroak
られていない場合、テストから完全なコールスタックを取得するにはどうすればよいconfess
ですか?