目前,自动化测试框架已经基本成型。朋友们的一些建议,还在陆续消化中,在不久的将来或许都会加入到其中,谢谢大家的鼓励和支持。
最近,在一次技术交流会中,我的一位同事向我提起QTP(QuickTest Pro),肯定了它的描述性编程和我们框架中的设计有类似之处,并指出QTP的可扩展性比较强,比如流程控制(IF、LOOP、SWITCH等)。特别是装载数据批量操作软件方面比较强。我深以为然。
因此,我开始和我的另一位同事小贾琢磨。我们有两种选择,一是在脚本编辑中扩展有关流程的节点(这点很像FinalBuilder),还有就是支持脚本语言。我们选择了后者,因为第一种虽然可以扩展,但最终毕竟还是不灵活。
在对编程语法方面,一开始考虑的是PascalScript,因为我们都是使用的Delphi。但是考虑到测试人员并不是熟悉Delphi的,况且,对于脚本化编程,我最先想到的是Ruby,而不是Delphi。因此我做了一个大胆的假设,如果在我们引擎中,加入对Ruby的支持,应该怎么做呢?
首先是引擎调用Ruby脚本。我查找了一下资料。发现Delphi下有现成的开源控件,而且Ruby其实已经公布了API了。因此这不是问题了。
那么下面就是最重要的问题了,Ruby脚本如何调用引擎去控制控件?我将所有针对引擎的操作,都归结于控件的操作,这简化了依赖