在使您的应用程序成型过程中节省时间和精力
6w6Linux联盟Angel Rivera (rivera@us.ibm.com)
6w6Linux联盟软件工程师,VisualAge TeamConnection, IBM
6w6Linux联盟2001 年 3 月
6w6Linux联盟-------------------------------------------------------
6w6Linux联盟创建脚本
6w6Linux联盟功能测试是软件开发的一个关键部分 -- 而已经装入 Linux 的 Bash 可以帮您轻而易举地完成功能测试。在本文中,Angel Rivera 将说明如何运用 Bash shell 脚本通过行命令来执行 Linux 应用程序的功能测试。由于此脚本依赖于命令行的返回码,因而您不能将这种方法运用于 GUI 应用程序。
6w6Linux联盟6w6Linux联盟功能测试是开发周期的一个阶段,在这个阶段中将测试软件应用程序以确保软件的函数如预期的那样,同时能正确处理代码中错误。此项工作通常在单个模块的单元测试结束之后,在负载/重压条件下整个产品的系统测试之前进行的。
6w6Linux联盟6w6Linux联盟市场上有许多测试工具提供了有助于功能测试的功能。然而,首先要获取它们,然后再安装、配置,这将占用您宝贵的时间和精力。Bash 可以帮您免去这些烦琐的事从而可以加快测试的进程。
6w6Linux联盟6w6Linux联盟使用 Bash shell 脚本进行功能测试的优点在于:
6w6Linux联盟Bash shell 脚本已经在 Linux 系统中安装和配置好了。不必再花时间准备它。
6w6Linux联盟可以使用由 Linux 提供的文本编辑器如 vi 创建和修改 Bash shell 脚本。不需要再为创建测试程序而获取专门的工具。
6w6Linux联盟如果已经知道了如何开发 Bourne 或 Korn shell 脚本,那对于如何运用 Bash shell 脚本已经足够了。对您来说,学习曲线已不存在了。
6w6Linux联盟Bash shell 提供了大量的编程构造用于开发从非常简单到中等复杂的脚本。
6w6Linux联盟6w6Linux联盟将脚本从 Korn 移植到 Bash 时的建议
6w6Linux联盟如果已有现成的 Korn shell 脚本,而想要将它们移植到 Bash,就需要考虑下列情况:
6w6Linux联盟6w6Linux联盟Korn 的 "print" 命令在 Bash 中不能使用;而是改为使用 "echo" 命令。
6w6Linux联盟需要将脚本的第一行:
6w6Linux联盟#!/usr/bin/ksh
6w6Linux联盟修改成:
6w6Linux联盟#!/bin/bash
6w6Linux联盟6w6Linux联盟创建 Bash shell 脚本进行功能测试
6w6Linux联盟这些基本的步骤和建议适用于许多在 Linux 上运行的客户机/服务器应用程序。
6w6Linux联盟6w6Linux联盟记录运行脚本的先决条件和主要步骤
6w6Linux联盟将操作分成若干个逻辑组
6w6Linux联盟基于一般方案制定执行步骤
6w6Linux联盟在每个 shell 脚本中提供注释和说明
6w6Linux联盟做一个初始备份以创建基准线
6w6Linux联盟检查输入参数和环境变量
6w6Linux联盟尝试提供 "usuage" 反馈
6w6Linux联盟尝试提供一个"安静"的运行模式
6w6Linux联盟当出现错误时,提供一个函数终止脚本
6w6Linux联盟如可能,提供可以执行单个任务的函数
6w6Linux联盟当显示正在生成的输出时,捕获每个脚本的输出
6w6Linux联盟在每个脚本内,捕获每个行命令的返回码
6w6Linux联盟计算失败事务的次数
6w6Linux联盟在输出文件中,突出显示错误消息,以便于标识
6w6Linux联盟如有可能,"实时"生成文件
6w6Linux联盟在执行脚本的过程中提供反馈
6w6Linux联盟提供脚本执行的摘要
6w6Linux联盟提供一个容易解释的输出文件
6w6Linux联盟如有可能,提供清除脚本及返回基准线的方法
6w6Linux联盟6w6Linux联盟6w6Linux联盟6w6Linux联盟下面详细讲述了每一条建议以及用于说明问题的脚本。若要下载此脚本,请参阅本文后面的参考资料部分。
6w6Linux联盟6w6Linux联盟6w6Linux联盟1. 记录运行脚本的先决条件和主要步骤
6w6Linux联盟记录,尤其是以有自述标题的单个文件(例如 "README-testing.txt")记录功能测试的主要想法是很重要的,包括,如先决条件、服务器和客户机的设置、脚本遵循的整个(或详细的)步骤、如何检查脚本的成功/失败、如何执行清除和重新启动测试。
6w6Linux联盟6w6Linux联盟6w6Linux联盟2. 将操作分成若干个逻辑组
6w6Linux联盟如果仅仅执行数量非常少的操作,可以将它们全部放在一个简单的 shell 脚本中。
6w6Linux联盟6w6Linux联盟6w6Linux联盟但是,如果需要执行一些数量很多的操作,那最好是将它们分成若干个逻辑集合,例如将一些服务器操作放在一个文件而将客户机操作放在在另一个文件中。通过这种方法,划分适当的颗粒度来执行测试和维护测试。
6w6Linux联盟6w6Linux联盟6w6Linux联盟3. 基于一般方案制定执行步骤
6w6Linux联盟一旦决定对操作进行分组,需要根据一般方案考虑执行操作的步骤。此想法是模拟实际生活中最终用户的情形。作为一个总体原则,只需集中测试 80% 最常调用函数的 20% 用法即可。
6w6Linux联盟6w6Linux联盟6w6Linux联盟例如,假设应用程序要求 3 个测试组以某个特定的顺序排列。每个测试组可以放在一个带有自我描述文件名(如果可能)的文件中,并用号码来帮助识别每个文件的顺序,例如:
6w6Linux联盟6w6Linux联盟代码:
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 脚本中提供注释和说明
6w6Linux联盟在每个 shell 脚本的头文件中提供相关的注释和说明是一个良好的编码习惯。这样的话,当另一个测试者运行该脚本时,测试者就能清楚地了解每个脚本中测试的范围、所有先决条件和警告。
6w6Linux联盟6w6Linux联盟6w6Linux联盟下面是一个 Bash 脚本 "test-bucket-1" 的示例 。
6w6Linux联盟6w6Linux联盟6w6Linux联盟代码:
#!/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.