大佬教程收集整理的这篇文章主要介绍了perl – 如何规划外部子运行的其他测试?,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
当然,解析器的API完全相同,只是从用于测试解析的示例文件中读取的数据不同.为了简化测试文件,我写了一个sub,它传递了解析器对象和表示预期数据的哈希结构.看起来像
@H_318_4@my $parser = new MyApp::Parser($filE); test_nested_objects = ($parser,{ property1 => "value",property2 => 123,subobject_accessor => { property3 => "foobar",} }子test_nested_object遍历散列并运行对散列中定义的所有属性的测试,例如如果可以调用subobject_accessor,则返回一个对象,该对象可以被称为property3.
我检查了整个* .t文件运行了多少个测试并添加了tests => 123到所有* .t文件.现在,我在泛型函数中添加了一些检查,所有计划都是错误的.
如何让我的计划了解子测试?我想实现以下目标:
>在运行它们之前给出的测试次数以查看progess
>总数自动增加→编辑子时无需手动更改数字
>运行时在sub中可见的单个测试(在sub中隐藏测试并返回0或1是不可接受的,因为我真的需要知道解析数据有什么问题)
我希望你能够明白.对不起,但我认为如果没有一些背景知识,人们可能会理解.
done_tesTing();
测试计划的许多用途仅用于确保测试脚本完成.如果它看到了正确数量的测试,那么脚本必须一直到最后.这不是真的,但它是一个方便和可行的小说.
如果您必须进行一些计算来确定测试的数量,例如测量数据结构的大小,那么请执行此操作,然后再调用计划:
use Test::More; # don't declare the plan yet my $test_count = ...; plan tests => $test_count;
但是,您可以将测试划分为子测试,而不是制定大计划.每个子测试只需知道它运行了多少测试,脚本只需要知道子测试的数量:
subtest some_label => sub { plan tests => $n; ... };
您对测试函数的每次调用都将是一次测试,并且该函数将使用子测试来执行它想要执行的任何操作而不会向其调用者暴露太多.
以上是大佬教程为你收集整理的perl – 如何规划外部子运行的其他测试?全部内容,希望文章能够帮你解决perl – 如何规划外部子运行的其他测试?所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。