引子

  作为一个无 dev 经验的 tester 来说,目前遇到许多新的问题,关于 tester 以后的人员基本素质的构成,现在也有许多说法,在这里,不想过多的铺开讨论了。 作为一个 tester,本身当然必须对test这件事情感兴趣,才能把工作做好。 有的人天生喜欢找茬,喜欢提意见,在我看来,是一个不错的 tester 的料。 当你天天对着同一个产品的不同版本不停的测试的时候,自然会产生一些怨言,由此产生懈怠。

  “某些功能点我都连着测试了 N 个版本了,肯定不会出错了” “这种基本功能点,怎么可能出错”这样的论调是很有可能产生的。于是,一个 tester 很有可能在某次 release 的过程中,经验主义的放过了某些功能点的测试。 几天后,一个用户反馈上来,那个功能点出了问题.........

  “偷懒”这个词语,在测试过程中,不应该算一个贬义词(当然了,故意漏过功能点不测试,不在此列)。因为“偷懒”催生新的技术,“偷懒”节省更多的时间。 我相信,自动化测试是这样来的。

  正题

  任何事情都可以分解为很小的部分,让我们先分析一下,手工执行测试案例的一个过程:

  打开被测软件

  执行测试案例

  给出测试结果

  然后,我们不断重复这个过程。 后给出测试报告。

  显然,我们的自动化测试也要满足上面的这个过程中的所有要求。 既然是自动化,首先要求是所有的测试用例可以无人值守运行;其次,每个测试用例都由机器来模拟人对软件的操作;第三,某个测试用例失败不能影响其他测试用例的继续执行;第四,测试数据和测试用例好分离开来;后一点,测试结束之后,给个报告或者给个图告知测试结果。

  根据上面的分析,我们逐个来一一解决,当然了,本篇都是很初级的解决方式,相信有许多大牛会有更好的方式来解决。

  无人值守运行,那么 python 的 unittest 的框架能达到这个目的。

  模拟人的操作, selenium 可以胜任。

  测试用例间无影响, 同1

  数据分离, 那把测试数据都扔xml里。

  待完善 (本例中 只是在部分方法中添加错误提示)

  开始动手

  对 python 的 unittest 进行一些小手术,当然了,如果只追求简单,直接用也行。

def assertLogEqual(self, arg1, arg2):
print "[assertLogEqual('"+arg1+"', '"+arg2+"')]: "
if arg1 != arg2:
self.anyfailure = True
print " -> Failed: not equal"
self.result_note = " '%s' and 's%' is not equal "%(arg1,arg2)
else:
print " ->OK"
self.result_note = "%s OK " % self.result_note
self.assertEqual(arg1, arg2)
def assertLogTrue(self, arg1, note=""):
print "[assertLogTrue("+str(arg1)+")]: "+note
if arg1 is False:
self.anyfailure = True
print " -> Failed: Excepting True"
self.result_note = " %sError: %s " % (self.result_note, note)
else:
print " ->OK"
self.resulte_note = "%s OK " % self.result_note
self.assertTrue(arg1)
def assertLogFalse(self, arg1, note=""):
print "[assertLogFalse("+str(arg1)+")]: "+note
if arg1 is True:
print " ->FAILED: Expecting False."
self.anyfailure = True
self.result_note = "%sError: %s " % (self.result_note, note)
else:
self.result_note = "%sOK " % self.result_note
print " ->OK"
self.assertFalse(arg1)