目前手里有个测试项目各个feature的测试用例都放在对应的子目录下,虽然有自动化测试框架的帮助执行起来很方便,但是偶尔也有需要在本地执行某个feature的全部测试用例集合。因为本人对shell脚本不熟悉,所以Ruby的问题还是用Ruby来解决。
每个测试脚本的命名遵循如下规范:Testlink ID + 测试用例名字。比如100_invalid_signature.rb表示该测试用例在Testlink里的ID是100,用来测试无效签名。在脚本的实现中,测试用例的名字就对应为TC_100。例子代码如下:
class TC_100 < Test::Unit::TestCase
# ...
end
既然有规范存在,那么一切都好说。我只要把100_invalid_signature.rb文件读入,那么通过文件名分析就知道必然存在一个测试用例类名为TC_100,把它塞到测试集合中,最后运行这个测试集合就可以了。例子代码如下:
require 'test/unit/testsuite'
require 'test/unit/ui/console/testrunner' path = ARGV[0] # 测试脚本所在的目录
$suite_names = [] Dir.foreach(path) do |filename|
if /d+_/ =~ filename # 我们的命名规范是数字开头,下划线然后是简单描述。
require "#{path}/#{filename}"
testcase_id = filename.split('_')[0]
$suite_names << "TC_#{testcase_id}"
end
end class Suites << Test::Unit::TestSuite
def self.suit
suites = self.new('Suites')
suite_names.each do |suite_name|
suites << eval("::#{suite_name}.suite") # 这段是关键,利用eval就等于动态的插入了一段代码。
end
end
end Test::Unit::UI::Console::TestRunner.run(Suites)