使用 Bash shell脚本进行功能测试
在使您的应用程序成型过程中节省时间和精力
Angel Rivera
2001 年 3 月 01 日发布
功能测试是开发周期的一个阶段,在这个阶段中将测试软件应用程序以确保软件的函数如预期的那样,同时能正确处理代码中错误。此项工作通常在单个模块的单元测试结束之后,在负载/重压条件下整个产品的系统测试之前进行的。
市场上有许多测试工具提供了有助于功能测试的功能。然而,首先要获取它们,然后再安装、配置,这将占用您宝贵的时间和精力。Bash
可以帮您免去这些烦琐的事从而可以加快测试的进程。
使用 Bash shell 脚本进行功能测试的优点在于:Bash shell 脚本已经在 Linux
系统中安装和配置好了。不必再花时间准备它。
可以使用由 Linux 提供的文本编辑器如 vi 创建和修改 Bash shell
脚本。不需要再为创建测试程序而获取专门的工具。
如果已经知道了如何开发 Bourne 或 Korn shell
脚本,那对于如何运用 Bash shell
脚本已经足够了。对您来说,学习曲线已不存在了。
Bash shell
提供了大量的编程构造用于开发从非常简单到中等复杂的脚本。
将脚本从 Korn 移植到 Bash
时的建议
如果已有现成的 Korn shell 脚本,而想要将它们移植到
Bash,就需要考虑下列情况:Korn 的 "print" 命令在 Bash 中不能使用;而是改为使用 "echo"
命令。
需要将脚本的第一行:
#!/usr/bin/ksh
修改成:
#!/bin/bash
创建 Bash shell
脚本进行功能测试
这些基本的步骤和建议适用于许多在 Linux
上运行的客户机/服务器应用程序。记录运行脚本的先决条件和主要步骤
将操作分成若干个逻辑组
基于一般方案制定执行步骤
在每个 shell 脚本中提供注释和说明
做一个初始备份以创建基准线
检查输入参数和环境变量
尝试提供 "usuage" 反馈
尝试提供一个“安静”的运行模式
当出现错误时,提供一个函数终止脚本
如可能,提供可以执行单个任务的函数
当显示正在生成的输出时,捕获每个脚本的输出
在每个脚本内,捕获每个行命令的返回码
计算失败事务的次数
在输出文件中,突出显示错误消息,以便于标识
如有可能,“实时”生成文件
在执行脚本的过程中提供反馈
提供脚本执行的摘要
提供一个容易解释的输出文件
如有可能,提供清除脚本及返回基准线的方法
下面详细讲述了每一条建议以及用于说明问题的脚本。若要下载此脚本,请参阅本文后面的
参考资料部分。
1. 记录运行脚本的先决条件和主要步骤
记录,尤其是以有自述标题的单个文件(例如
"README-testing.txt")记录功能测试的主要想法是很重要的,包括,如先决条件、服务器和客户机的设置、脚本遵循的整个(或详细的)步骤、如何检查脚本的成功/失败、如何执行清除和重新启动测试。
2. 将操作分成若干个逻辑组
如果仅仅执行数量非常少的操作,可以将它们全部放在一个简单的 shell
脚本中。
但是,如果需要执行一些数量很多的操作,那最好是将它们分成若干个逻辑集合,例如将一些服务器操作放在一个文件而将客户机操作放在在另一个文件中。通过这种方法,划分适当的颗粒度来执行测试和维护测试。
3. 基于一般方案制定执行步骤
一旦决定对操作进行分组,需要根据一般方案考虑执行操作的步骤。此想法是模拟实际生活中最终用户的情形。作为一个总体原则,只需集中测试
80% 最常调用函数的 20% 用法即可。
例如,假设应用程序要求 3
个测试组以某个特定的顺序排列。每个测试组可以放在一个带有自我描述文件名(如果可能)的文件中,并用号码来帮助识别每个文件的顺序,例如:1. fvt-setup-1: To perform initial setup.
2. fvt-server-2: To perform server commands.
3. fvt-client-3: To perform client commands.
4. fvt-cleanup: To cleanup the temporary files,
in order to prepare for the repetition
of the above test cases.
4. 在每个 shell 脚本中提供注释和说明
在每个 shell
脚本的头文件中提供相关的注释和说明是一个良好的编码习惯。这样的话,当另一个测试者运行该脚本时,测试者就能清楚地了解每个脚本中测试的范围、所有先决条件和警告。
下面是一个 Bash 脚本 "test-bucket-1" 的示例 。#!/bin/bash
#
# Name: test-bucket-1
#
# Purpose:
# Performs the test-bucket number 1 for Product X.
# (Actually, this is a sample shell script,
# which invokes some system commands
# to illustrate how to construct a Bash script)
#
# Notes:
# 1) The environment variable TEST_VAR must be set
# (as an example).
# 2) To invoke this shell script and redirect standard
# output and standard error to a file (such as
# test-bucket-1.out) do the following (the -s flag
# is "silent mode" to avoid prompts to the user):
#
# ./test-bucket-1 -s 2>&1 | tee test-bucket-1.out
#
# Return codes:
# 0 = All commands were successful
# 1