我花了一段时间,还花了许多不同来源的小片段并将它们融合在一起,但是我认为我有一个小的工作示例,足以向Perl新手演示Perl构建过程,包括单元测试和代码覆盖率分析和报告。(我在Windows XP Pro PC上使用ActiveState ActivePerl v5.10.0,模块:: Build,测试::更多,开发::封面)
从您的Perl项目的目录开始,然后在您的项目目录下创建一个“ lib”目录和一个“ t”目录:
HelloPerlBuildWorld
|
|----------> lib
|
|----------> t
在“ lib”目录中,创建一个名为“ HelloPerlBuildWorld.pm”的文本文件。该文件是您将要构建和测试的Perl模块。将以下内容粘贴到此文件中:
use strict;
use warnings;
package HelloPerlBuildWorld;
$HelloPerlBuildWorld::VERSION = '0.1';
sub hello {
return "Hello, Perl Build World!";
}
sub bye {
return "Goodbye, cruel world!";
}
sub repeat {
return 1;
}
sub argumentTest {
my ($booleanArg) = @_;
if (!defined($booleanArg)) {
return "null";
}
elsif ($booleanArg eq "false") {
return "false";
}
elsif ($booleanArg eq "true") {
return "true";
}
else {
return "unknown";
}
return "Unreachable code: cannot be covered";
}
1;
在“ t”目录中,创建一个名为“ HelloPerlBuildWorld.t”的文本文件。此文件是您的单元测试脚本,它将尝试完全测试上面的Perl模块。将以下内容粘贴到此文件中:
use strict;
use warnings;
use Test::More qw(no_plan);
BEGIN { use_ok('HelloPerlBuildWorld') };
require_ok( 'HelloPerlBuildWorld' );
my $helloCall = HelloPerlBuildWorld::hello();
like($helloCall, qr/Hello, .*World/, "hello() RE test");
is($helloCall, "Hello, Perl Build World!", "hello() IS test");
for (my $ctr=1; $ctr<=10; $ctr++) {
my $repeatCall = HelloPerlBuildWorld::repeat();
is($repeatCall, 1, "repeat() IS test");
}
my $argumentTestCall1 = HelloPerlBuildWorld::argumentTest();
is($argumentTestCall1, "null", "argumentTest() IS null test");
my $argumentTestCall2 = HelloPerlBuildWorld::argumentTest("true");
is($argumentTestCall2, "true", "argumentTest() IS true test");
my $argumentTestCall3 = HelloPerlBuildWorld::argumentTest("false");
is($argumentTestCall3, "false", "argumentTest() IS false test");
my $argumentTestCall4 = HelloPerlBuildWorld::argumentTest(123);
is($argumentTestCall4, "unknown", "argumentTest() IS unknown test");
现在,在顶级项目目录中备份,创建一个名为“ Build.PL”的文本文件。该文件将创建您的构建脚本,供以后使用。将以下内容粘贴到此文件中:
use strict;
use warnings;
use Module::Build;
my $builder = Module::Build->new(
module_name => 'HelloPerlBuildWorld',
license => 'perl',
dist_abstract => 'HelloPerlBuildWorld short description',
dist_author => 'Author Name <email_addy@goes.here>',
build_requires => {
'Test::More' => '0.10',
},
);
$builder->create_build_script();
这就是您需要的所有文件。现在,从顶级项目目录中的命令行中,键入以下命令:
perl Build.PL
您将看到类似于以下内容:
Checking prerequisites...
Looks good
Creating new 'Build' script for 'HelloPerlBuildWorld' version '0.1'
现在,您应该可以使用以下命令运行单元测试:
Build test
并看到类似以下内容:
Copying lib\HelloPerlBuildWorld.pm -> blib\lib\HelloPerlBuildWorld.pm
t\HelloPerlBuildWorld....ok
All tests successful.
Files=1, Tests=18, 0 wallclock secs ( 0.00 cusr + 0.00 csys = 0.00 CPU)
要使用代码覆盖率分析运行单元测试,请尝试以下操作:
Build testcover
您会看到一些如下的顺序:
t\HelloPerlBuildWorld....ok
All tests successful.
Files=1, Tests=18, 12 wallclock secs ( 0.00 cusr + 0.00 csys = 0.00 CPU)
cover
Reading database from D:/Documents and Settings/LeuchKW/workspace/HelloPerlBuildWorld/cover_db
----------------------------------- ------ ------ ------ ------ ------ ------
File stmt bran cond sub time total
----------------------------------- ------ ------ ------ ------ ------ ------
D:/Perl/lib/ActivePerl/Config.pm 0.0 0.0 0.0 0.0 n/a 0.0
D:/Perl/lib/ActiveState/Path.pm 0.0 0.0 0.0 0.0 n/a 0.0
D:/Perl/lib/AutoLoader.pm 0.0 0.0 0.0 0.0 n/a 0.0
D:/Perl/lib/B.pm 18.6 16.7 13.3 19.2 96.4 17.6
...
[SNIP]
...
D:/Perl/lib/re.pm 0.0 0.0 0.0 0.0 n/a 0.0
D:/Perl/lib/strict.pm 84.6 50.0 50.0 100.0 0.0 73.1
D:/Perl/lib/vars.pm 44.4 36.4 0.0 100.0 0.0 36.2
D:/Perl/lib/warnings.pm 15.3 12.1 0.0 11.1 0.0 12.0
D:/Perl/lib/warnings/register.pm 0.0 0.0 n/a 0.0 n/a 0.0
blib/lib/HelloPerlBuildWorld.pm 87.5 100.0 n/a 83.3 0.0 89.3
Total 9.9 4.6 2.8 11.3 100.0 7.6
----------------------------------- ------ ------ ------ ------ ------ ------
Writing HTML output to D:/Documents and Settings/LeuchKW/workspace/HelloPerlBuildWorld/cover_db/coverage.html ...
done.
(有人请告诉我如何配置Cover以忽略所有Perl库,而仅在我编写的单个文件上向我报告。根据CPAN文档,我无法使Cover过滤正常工作!)
现在,如果刷新顶级目录,则可以看到一个名为“ cover_db”的新子目录。进入该目录并双击“ coverage.html”文件,以在您喜欢的Web浏览器中打开代码覆盖率报告。它为您提供了一个漂亮的彩色编码超文本报告,您可以在其中单击文件名,并在报告的实际源代码旁边直接查看Perl模块的详细语句,分支,条件,子例程覆盖率统计信息。您可以在此报告中看到,我们根本没有涵盖“ bye()”例程,并且还有一些无法访问的代码没有如我们预期的那样被涵盖。
(来源:leucht.com)
要在IDE中自动执行此过程,您可以做的另一件事是制作更多“ Build.PL”类型的文件,这些文件明确执行我们上面通过命令行手动执行的一些构建目标。例如,我使用具有以下内容的“ BuildTest.PL”文件:
use strict;
use warnings;
use Module::Build;
my $build = Module::Build->resume (
properties => {
config_dir => '_build',
},
);
$build->dispatch('build');
$build->dispatch('test');
然后,我将IDE设置为通过单击鼠标即可执行此文件(通过“ perl BuiltTest.PL”),它会自动从IDE运行我的单元测试代码,而不是从命令行手动执行它。将“ dispatch('test')”替换为“ dispatch('testcover')”,以执行自动代码覆盖。键入“构建帮助”以获取Module :: Build可用的构建目标的完整列表。
Build build
然后执行Build test
呢?