首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

工厂设计模式在自动化中的引用(一)

在自动化测试的范围中,目前依据webdriver的,web应用测试框架有selenium2,对于移动app自动化的测试,有appium,selenium2和appium有很多的共同使用的地方,如对属性对象的定位,都是有id,name等,所以,完全可以把selenium2和appium整合到一个完整的框架中,这样的目的就是一个框架可以实现对web应用程序自动化的测试,也是可以实现对移动产品UI自动化的测试,同时selenium2和appium都提供了不同的API,这些可以放在个字独立的类下面,而把selenium2和appium对属性元素的定位方法,以及共同使用的方法,放在另外的一个类中,这样,测试web程序,就继承web对应的类,测试移动的产品,就继承移动对应的类。工厂设计模式正好符号这样的需求,即在一个工厂中,可以生产很多的产品,依据消费者的需求要什么,可以构造一个产品然后提供给消费者。因此,利用这样的一个理念,可以编写一个工厂的类Factory,再编写AutomationPage类,编写web和移动共同使用到的方法编写在这个类中,WebPage类和AppPage类全部继承AutomationPage类,同时WebPage类编写web应用程序使用到的方法进行封装,AppPage封装移动使用到的方法,具体实现的代码在dashPage.py的模块中,见实现的代码:

03
您找到你想要的搜索结果了吗?
是的
没有找到

初始python单元测试框架unittest与webdriver的关系(一)

unittest是属于python的单元测试框架,和java的junit,c#的nunit雷同,unittest的详细说明,具体见官方的地址:https://docs.python.org/2/library/unittest.html。unittest单元测试给我们提供了创建测试用例,测试套件,以及测试固件。unittest在安装pyhton以后,直接自带了,可以直接使用。作为单元测试,是对程序最小模块的一种敏捷化的测试,更多的是开发作为对自己代码质量的一种考核,测试驱动的方法中,测试先行,开发接着来。在自动化测试中,我们虽然没有按照这样的模式来,但是有一个基本的事实的,当我们把selenium2的API全部学习完后,但是作为自动化测试来说,我们不可能把N个测试点,写在一个python的文件里面,即使一个简单的文本输入框,我们要测试它的边界值,敏感字符等,如果写在一个文件中,执行失败后,我们得仔细的查看到底是边界值出问题了还是其他出问题了,导致该部分执行失败,显然,这样的自动化,不是我们想要的,也会给成本增加很多的,也无法达到自动化的要求,更加无法处理几百几千个测试用例的批量执行。那么,就让我们来了解神秘的unittest,unittest的关系图具体见如下截图的层级关系:

03
领券