utPLSQL示例三

示例二

1、将测试代码放入被测试的包中

有时候,通常是程序包很小并且测试程序代码数量有限,不需要为测试代码创建一个单独的包。此时,可以将设置程序、清除程序以及单元测试程序放入被测试的包中。接下来看两个例子。

1.1、测试一个简单的字符串函数

假设一个字符串包中只存在一个函数(参见str.pks与str.pkb文件):

 
 

现在需要测试该函数。因为不想创建一个单独的包,直接修改包规范。如下所示:

 
 

包体与测试一中的“测试一个标量函数”示例相同。但是执行测试时,需要告诉utPLSQL,测试代码位于被测试包中。

 
 

1.2、测试集合元素

utPLSQL提供了utAssert.eqColl与utAssert.eqCollAPI程序用于测试集合。

例如,考虑包fileIO:它实现了UTL_FILE包的一个路径特性。也就是说,当请求打开文件时,程序搜索按照顺序搜索每一个路径直到找到文件或者完成列表中的路径。以下是包规范的内容:

 
 

以上包中声明了一个公共集合,fileIO.dirs,用于存储路径。由于它是在包规范中声明的,可以使用utAssert.eqColl过程(如果集合隐藏在包体中,应该使用utAssert.eqCollAPI)。测试代码也位于该包中。同时声明了另一个公共的集合,fileIO.ut_dirs,将会把它与fileIO.setPath产生的路径进行比较。

以下是测试程序的实现:

该测试程序由三步组成:直接赋值生成测试集合;调用setPath程序生成事实集合;调用断言程序比较两个集合。注意传递给断言程序的是集合的名称。utAssert使用动态SQL创建一个“即时”PL/SQL块来比较集合的值。

2、使用非默认的前缀

utPLSQL默认的前缀是“ut_”,但并不是必须使用该前缀。有时候可能不想使用默认的前缀。例如,假设已经编写了一个包含10个过程的包,每个过程都已经包含了一个“ut_”前缀(它可能代表“Unified Tecnologies”或者“Underside Treatment”等等)。

因为该前缀没有硬编码到utPLSQL中,可以很容易地指定自己的前缀。可以在运行一个测试时指定,例如:

 
 

也可以在添加包到测试套件中时指定前缀,例如:

 
 

当然,如果指定了一个非默认的前缀,也必须在构建测试包时使用该前缀。例如:

 
 

要查看使用非默认前缀的包的示例,参见test_te_employee.pks与test_te_employee.pk文件。

3、创建并运行测试套件

通常,应用程序包含多个包。为了测试应用,必须测试所有的包。utPLSQL通过提供测试套件来简化这个操作。

以下是一个定义了用于PL/Vision的测试套件(部分)的示例脚本。PL/Vision是RevealNet的活动PL/SQL知识库中的一个代码库。

 
 

这是一个非常简单的测试套件定义。除了指定测试包代码的位置之外,都采用了默认值。

此外,还可以在参数seq_in中指定包的测试顺序。也可以指定在被测试的源码包中查找测试代码,等等。

 
 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24945919/viewspace-743739/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/24945919/viewspace-743739/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值