STAF(TheSoftwareTestingAutomationFramework)是发端于IBM的自动化测试框架,如果我没记错的 话,2000年的时候STAF就有版本了,不过那时的STAF比较简单,做不了多少事情。过去这么多年,STAF现已发展成一个庞大体系了。
STAF主页(http://staf.sourceforge.net/)对该软件介绍如下:
STAF是开源、跨平台、支持多语言 的自动化测试框架,它围绕于组件重用的理念,通过服务调用(比如处理调用、资源管理、登陆、监视等)帮助大家省去繁琐的自动化架构建设工作,大家只需集中 精力在自身自动化实施上。STAF为自动化测试建立了基础,在高层解决方案提供一种可插拨的机制,支持多种平台与多种语言。
使用 STAF可快速构造自动化测试环境,STAF的服务调用系统也让大家创建自动用例与管理自动用例更加方便。STAF在功能级别实施服务调用,各个服务端点 (称作STAF客户端)是对等的,从一个端点可直接调用另一端点(在另一台机器运行的程序)提供的服务。
换另一个角度看,STAF是一 种分布式远程调用体系,它具有如下特色:
Ø将环境需求最小化(包括硬件与软件)
Ø在各种语言中都很 容易使用,包括Java,C/C++,Rexx,Perl,TCL,及命令行shell环境
Ø易于扩展,让用户能方便的创建一个服务插入到STAF体系中
STAF比较适应需要构造复杂测试环境的场合,复杂测试环境通常是分布式的,通过STAF将测试任务分发到 不同的测试环境去执行,可以方便的测试机的测试脚本,可以方便的收集测试结果,另外,执行引擎 STAX(SoftwareTestAutomationeXecutionEngine)让STAF的使用变得更简单,测试人员只需要配置XML文件便 实现STAF任务管理。
几个概念
服务(Services):
STAF是基于服务 (Services)来构建自动化框架的,服务就是STAF的可重用组件,服务还是一系列功能的集合。
如何理解STAF与服务的关系?STAF是一个小巧的后台程序,在STAF中使用的所有组件都是服务,STAF提供轻量级分发机制,负责将请求转发给这些服务。
STAF中服务分两种:Internal(内部服务)和External(外部服务)。内部服务被集成进STAFProc,提供一些关键性的功能,比如数据管理与同步,外部服务则由STAFProc动态装入,通过共享库(sharedlibraries)来访问。
STAF中常见服务有:
Ø ProcessService:这是内部服务,用来调用外部程序 [Page]
Ø FileSystemService:这是内部服务,可以对文件进行复制、删除、查看等操作
Ø LogService:这是外部 服务,用于日志的记录和查看
Ø ResPoolService:这是外部服务,提供查看、创建、删除等针对资源池的管理或操作
Ø MonitorService:这是外部服务,提供运行监控功能
Ø SemService:这是内部服务,提供 mutex和event信号量操作
Ø ZipService:这是外部服务,提供压缩与解压
Ø PingService:这是内部服务,用来检测远程STAF是否在运行
请求/响应:
STAF的服务以字符串形式表 达,每个请求都有三个参数(系统、服务、参数),第一个参数指示目标STAF系统,该参数由STAFProc解析以便确定是在本地处理还是发送到远端 STAF系统,第二个参数指示调用哪个服务,第三个参数运行服务的参数。当服务处理结束将返回两类数据,一是表示服务处理结果的返回码,二是服务返回特定 数据。
执行引擎:
STAX是基于STAF的执行引擎,它采用XML格式描述。在XML文件中可定义测试工作流,可以 实现并行执行、嵌套测试用例、控制运行时间等,STAX支持Java和Python模块。
这里我讲的是STAF的本地服务,STAF的跨机测试控制无疑非常强大,适应平台 与编程接口都很丰富。