selenium自动化测试框架,如何利用selenium来进行自动化页面测试
selenium自动化测试框架,如何利用selenium来进行自动化页面测试详细介绍
本文目录一览: 怎么用python做自动化测试?
Python是一种广泛使用的编程语言,也被广泛应用于自动化测试领域。以下是用Python进行自动化测试的步骤:
安装 Python环境和所需的测试框架,如unittest、pytest或behave等。
编写测试用例。在编写测试用例时,需要明确测试的目标和预期结果,同时指定测试数据。
建立测试框架。测试框架是负责测试用例的执行、结果处理以及报告生成的重要组成部分。
运行测试用例。使用测试框架来运行测试用例并记录测试结果。
分析测试结果。分析测试结果以确定哪些测试失败,找出失败的原因,并修复故障。
重复测试过程,直到所有测试都通过。
使用Python进行自动化测试的优势在于它非常容易学习和使用,同时还支持各种类型的测试,如单元测试、集成测试和功能测试等。此外,Python还支持各种领域特定语言(DSL),如Behave,能够简化测试脚本的编写。
这里以web自动化测试为例,简单介绍一下如何使用python进行web自动化测试,主要用到selenium这个框架,实验环境win10+python3.6,主要内容如下:
1.首先,安装selenium框架,这个直接在cmd窗口输入命令“pipinstallselenium”就行,如下,安装非常快:
2.安装完成后,还需要安装浏览器驱动程序,不然直接运行程序会报错,以谷歌浏览器chrome为例,需要下载chromedriver驱动程序,如下,这里chromedriver的版本必须要与自己平台浏览器的版本匹配:
下载完成后,是一个zip压缩包,里面就一个chromedriver.exe文件,这里需要将这个文件复制到python安装目录下,如下:
3.最后,我们就可以进行selenium框架测试了,测试代码如下,非常简单,创建一个webdriver,如果能正常打开对应网页,则说明selenium安装成功:
之后就可以直接定位相关元素,进行web自动化测试了,主要方法如下(共有8种),分别是id、name、classname、tagname、linktext、partiallinktext、xpath和cssselector,这里可以自行测试,相关资料非常丰富:
至此,我们就完成了pythonweb自动化测试框架selenium的安装和简单使用。总的来说,整个过程非常简单,只要你有一定的python基础,熟悉一下上面的安装过程,很快就能搭建好本地selenium自动化测试框架,网上也有相关教程和资料,介绍的非常详细,感兴趣的话,可以搜一下,希望以上分享的内容能对你有所帮助吧,也欢迎大家评论、留言进行补充。
北大青鸟设计培训:自动化测试常用工具有哪些?
自动化测试的问题我们已经探讨了很多次了,所以今天我们就给大家简单分享了在自动化测试过程中常用的一些测试工具和方法,下面java课程http://www.kmbdqn.cn/就一起来了解一下吧。希望通过对本文的阅读,能够提高大家对自动化测试的认识和理解。1.带RobotFramework的SeleniumSelenium无疑是受欢迎的Web自动化测试工具。其开源的特性是被广泛使用的原因之一。您可以使用不同的语言在Selenium中实施各种框架,从而为自动化测试提供更多的功能。Selenium能够支持多种操作系统(Windows、Mac、Linux)和多种浏览器(Chrome、火狐、IE和Headless类型浏览器)。我们可以运用多种语言(如Java、Groovy、Python、C#、PHP、Ruby和Perl)来开发出不同的测试脚本。Selenium内置了许多工具和框架,您可以启用它们来进行持续测试。RobotFramework是Selenium用来进行持续测试的一种常用的框架。通过Robot,您可以运行各种自动化测试,包括由SeleniumWebdriver所提供的、基于UI元素和API的测试。Selenium既可以使用关键字驱动的方法进行验收测试,也可以进行验收测试驱动式的开发(AcceptanceTest-DrivenDevelopment,ATDD)。通过使用Python和Java所实现的附加测试库,其测试功能得到了进一步扩展。而RobotFramework不仅可以用于Web应用的测试,也可被用来测试Android和iOS的应用。但是,Selenium本身并不能满足所有的持续测试需求。它需要与大量的工具相集成,以满足在软件开发生命周期(SDLC)中的不同目的。此外,Selenium还需要使用者具有高级的编程技能,并愿意花费专门的时间与精力,来构建自动化框架,以满足其特定的测试需求。2.TestsigmaTestsigma是一个统一的、以AI驱动测试的自动化平台。它采用Shift-Left方法,将持续测试集成到了端到端的持续交付生态系统之中。Testsigma通过减少自动化测试技术中的复杂性,为功能和自动化团队带来了更多的灵活性。功能测试人员可以轻松地使用自然语言,编写出简化的代码,来进行自动化测试。Testsigma通过可重用的步骤组合、与集中对象存储库(CentralizedObjectRepository)大限度地提高了测试代码的重用性。同时它通过使用AI,来大幅降低了与测试有关的维护开销。Testsigma能够与各种开源的或三方工具相集成。它支持上千种不同“设备+浏览器+操作系统”组合的云端测试环境,以不断满足各种的动态测试需求。Testsigma能为企业级的自动化测试、和持续测试提供所有必需的功能,其中包括:数据驱动测试、跨浏览器测试、可重用性测试套件、测试计划与数据管理、电子邮件与Slack通知、并行测试执行、集中对象/元素存储库、综合报告、与CI工具的集成、以及自动化Bug报告等。作为一款基于云端的自动化测试工具,Testsigma为Web、移动Web、Android、iOS应用、以及RESTful服务提供了各种类型的应用支持。3.IBMRationalFunctionalTesterRFT是另一种能够进行功能、API、性能和回归测试的工具。RationalFunctionalTester使用记录和回放来创建自动化的功能测试,并将预期结果与执行时系统所产生的实际结果相比较。IBM支持广泛的应用程序,并能够与IBMRationalQualityManager等工具相集成。另外,IBMRationalTestWorkbench还支持在API级别、用户界面级别、以及整个系统级别进行回归测试,以实现在DevOps或持续交付生命周期内的各种测试目标。
怎样开始用selenium进行自动化测试?
作为一个之前没接触过selenium的新手来说,如果之前有过写代码的经验,那么学习起来就会更加快速!但无论如何,开始总是比较难的!我也是从一个接近纯24K小白成长起来的,一步一个脚印,在这个过程中我学习到了很多新的知识,有了新的突破,新的成长,不断地努力,不断地尝试,不断地总结经验,让我一直走到了今天,未来,还有很多路要走!义无反顾,我的测试之路!所以,今天抽空回顾一下我的selenium学习过程,也就是,selenium自动化测试怎么开始,这些,是我的个人经验,分享出来给大家参考!一开始,基本上很多人都是用selenium IDE录制脚本开始的,我也是!有一本书写得很不错:selenium初学者指南!So,从录制回放开始我的selenium,而在这个过程中,不断地去补充我的html css知识,熟悉selenium的api!慢慢地,发现录制的脚本在回放的时候经常报错,通过检查发现,是定位上的错误,导致这种定位的错误的最大原因是系统前端采用了某种框架,如tigerUI,exj....所以HTML里面的标签很多都是动态的,比如id,class,name!这对selenium操作定位的元素而进行自动化来说是致命伤!所以,开始自己写定位信息,这已经是必须的了!从而学习了xpth和css选择器,掌握了更加有效,快速和稳定地定位页面上的元素(定位的时候难免会碰到有iframe,这就得先切换到iframe中再进行定位了)!也就是,在selenium IDE上写脚本!信心满满地在selenium IDE上写了长长地一段脚本,并且反复跑都能成功!总算尝到了一点点幸福的滋味!然后呢,问题来了,当我要修改和扩展这段的脚本的时候,才发现这效率是相当地低!一句句查!一句句改!多么痛的领悟!另外,selenium IDE 默认启动的是火狐,在使用selenium RC 启动 IE 进行跑脚本时浏览器总是会报错!各种搞不定,各种不淡定!决定放弃使用IDE!selenium有一个强大之处就是支持多种语方:java,C#,python等等,并且可以把录制的脚本转换成代码!我用的是java,果断走起!不用说,当然是把脚本转为java代码了,在Eclipse中重新开始搞!选择一个测试框架:有Junit和TestNg两个选择,公司用的是junit,所以,不用多说,我就用junit验证selenium脚本的运行结果!并且,Junit和TestNG都可以生成比较直观的测试报告!写好一些代码,会看到整段代码中密密麻麻充斥着基本相同的代码:开始封装代码!把常用到API封装起来!封装好之后代码看着就舒服多了!接下来,是不是也应该把代码中的定位信息用一个专门的文件放起来,再去读取里面的定位信息,这样,维护代码和维护定位信息就放在了两个地方,不用老是扎在代码和定位路径中,简单地分一下层!果断尝试!到这里,脚本写出来了,常用的api封装起来了,定位路径分离出来了!整个代码简洁多了!写起来容易和舒服多了!这时候,该个性化定制一下自己的框架了,这里,就暂时不写下去了,已经离怎样开始selenium挺远的了!或许,到了这一步,你早就有自己对测试框架的想法和对脚本的设计方法了。。。。加油吧,把想法化为实际的动力,继续向前!
什么是ui自动化测试
自动化测试分为黑盒测试,和白盒测试,就是把被测程序当作一个盒子,能看到代码的成为白盒测试,不能看到代码的成为黑盒测试,ui测试是不能看到代码,只基于程序功能的测试;ui自动化测试,是通过java/python等语言进行自动化操作程序的测试;我用的是python,unittest框架 + selenium框架(电脑端);能够通过程序模拟人的操作进行反复的测试;手机端用的是appium框架,来操作手机或者平板;纯手写,欢迎采纳!
UI自动化测试主要涉及通过编写自动化测试脚本来对图形用户界面(UI)进行测试。这一过程主要是为了实现测试用例的自动执行,从而提高测试效率,并降低人工测试的成本。具体而言,UI自动化测试的主要步骤包括:
1. 准备测试环境:在此阶段,需要安装所需的测试框架,如Selenium、Appium等,以及浏览器驱动程序如ChromeDriver、GeckoDriver等,以便于进行UI自动化测试。
2. 定位UI元素:这一步骤主要是通过使用定位工具或代码来获取页面元素的定位信息,如元素的id、name、xpath等。这些信息将用于在测试脚本中实现对UI元素的操作和控制。
3. 编写测试脚本:在此阶段,需要使用selenium、appium等测试框架的API,根据业务需求编写具体的测试脚本。这些脚本将根据预先定义的测试用例,实现对UI元素的操作和交互。
4. 配置和运行:在配置阶段,需要根据实际情况配置浏览器、设备等信息,以确保自动化测试的正确性和稳定性。一旦配置完成,就可以运行自动化测试脚本了。
5. 生成测试报告:脚本运行完成后,需要根据执行结果生成相应的测试报告,记录每个测试用例的执行结果,以便于后续的分析和改进。
6. 维护脚本:由于UI可能经常发生变化,因此需要定期维护测试脚本,确保脚本的可用性和稳定性。如果UI发生变化,相应的测试脚本也需要进行相应的调整和更新。
目前比较流行的UI自动化测试工具有Selenium、无缺测试、Appium、Pytest、Robot Framework等。与手工测试相比,UI自动化测试具有以下优势:
1. 执行效率高:自动化测试脚本可以快速地执行大量的测试用例,从而大大缩短了测试周期。
2. 可重复性强:自动化测试脚本可以按照预设的测试用例重复执行,避免了手工测试中可能出现的疏漏和错误。
3. 减少人力成本:通过自动化测试,可以大大减少人力投入,降低了测试成本。
然而,需要注意的是,UI自动化测试也存在一些问题,如:
元素定位变化:由于UI经常发生变化,可能会导致原有的定位方式无法再正确地找到元素,从而造成测试失败。
同步性问题:在UI自动化测试中,需要对页面元素进行同步操作,如果页面元素尚未加载完成就进行了操作,可能会导致测试失败。
异常处理:在自动化测试过程中,可能会遇到各种异常情况,如网络中断、浏览器崩溃等,如何处理这些异常情况也是需要考虑的问题。
Python自动化测试框架有哪些?
1、Unittest
是python内置的标准类库,它的API跟java的Junit、.net的NUnit、C++的CppUnit很相似,通过继承unittest.TestCase来创建一个测试用例。
2、 Doctest
Doctest模块会搜索那些看起来像交互式会话的python代码片段,然后尝试执行并验证结果,即使从来没有接触过Doctest,我们也可以从这个名字中窥到一丝端倪,它看起来就好像代码里的文档字符串(docstring)一样。
3、py.test
是python的一种单元测试框架,与python自带的unittest测试框架类似,但是比unittest框架使用起来更加简洁、效率更高;根据官方介绍,它具有以下特点:非常容易上手、入门简单、文档丰富,有很多实例可以参考;能够支持简单的单元测试和复杂的功能测试;支持参数化;支持重复执行失败的case。
4、Nose
Nose是对unittest的扩展,使得python的测试更加简单,Nose自动发现测试代码并执行,提供了大量的插件,nose不是python自带模块,需要用pip安装。
5、tox
最大的特色,是自动化测试环境的管理以及使用多个解析器配置进行测试;
6、Unittest2
是Unittest的升级版本,对API进行了改善以及更好的诊断语法。
有很多,目前比较常用的是RobotFramework框架。兼容性很好,同时可以满足java、c、python模块的调用
图形界面,有操作有内置方法函数,很多扩展模块,很方便
1、Pytest
适用于多种软件测试的Pytest,是另一个Python类型的自动化测试框架。凭借着其开源和易学的特点,该工具经常被QA团队、开发团队、个人团队以及各种开源项目所使用。鉴于Pytest具有断言重写之类的实用功能,许多大型互联网应用,如Dropbox和Mozilla,都已经从下面将要提到的unittest切换到Pytest之上。
2、Robot Framework
作为重要的Python测试框架之一,Robot Framework主要被用在测试驱动类型的开发与验收中。虽然是由Python开发而来,但是它也可以在基于.net的IronPython和基于Java的Jython上运行。同时,作为一个Python框架,Robot还能够兼容诸如Windows、MacOS、以及Linux等平台。
3、UnitTest/PyUnit
受到了JUnit启发的UnitTest/PyUnit,也是一种标准化的针对单元测试的Python类自动化测试框架。它的基类TestCase提供了各种断言方法、以及所有清理和设置的例程。因此,TestCase子类中的每一种方法都是以test作为名词前缀,以标识它们能够被作为测试用例所运行。用户可以使用load方法和TestSuite类来分组、并加载各种测试。当然,您也可以通过联合使用,来构建自定义的测试运行器。正如我们使用Junit去测试selenium那样,UnitTest也会用到UnitTest-sml-reporting、并能生成各种xml类型的报告。
4、Behave
我们都知道:行为驱动开发,是一种基于敏捷软件开发的方法。它能够鼓励开发人员、业务参与者和QA人员,三者之间的协作。作为另一种Python测试框架,Behave允许团队避开各种复杂的情况,去执行BDD测试。从本质上说,该框架与SpecFlow和Cucumber非常相似,常被用于执行自动化测试。用户可以通过简单易读的语言来编写测试用例,并能够在其执行期间粘贴到代码之中。而且,那些被设定的行为规范与步骤,也可以被重用到其他的测试方案中。
5、Lettuce
Lettuce是另一种基于Cucumber和Python的行为驱动类自动化工具。Lettuce主要专注于那些具有行为驱动开发特征的普通任务。它不但简单易用,而且能够使得整个测试过程更流畅、甚至更有趣。
如何利用selenium来进行自动化页面测试
1. 下载必要依赖文件selenium-server-standalone-2.25.0.jar, junit-4.7.jar,并将它们放置到工程的lib文件夹下面 (我这里使用Firefox浏览器来作为客户端,所以就不需要下载额外的浏览器执行器,如果你想用IE或是Chrome做客户端,请下载对应的执行器
2. 建立一个测试工程,在工程里创建一个测试文件,并添加如下代码:
import com.thoughtworks.selenium.Selenium;
import junit.framework.TestCase;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.BlockJUnit4ClassRunner;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebDriverBackedSelenium;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.openqa.selenium.internal.WrapsDriver;
import org.openqa.selenium.support.ui.Wait;
import org.openqa.selenium.support.ui.WebDriverWait;
import java.io.IOException;
import static org.openqa.selenium.support.ui.ExpectedConditions.visibilityOfElementLocated;
@RunWith(BlockJUnit4ClassRunner.class)
public class pickTest extends TestCase {
protected static Selenium selenium;
private static WebDriver driver;
@Before
public void createAndStartService() throws IOException {
selenium = new WebDriverBackedSelenium(new FirefoxDriver(), "");
driver = ((WrapsDriver) selenium).getWrappedDriver();
}
@After
public void createAndStopService() {
driver.quit();
}
@Test
public void should_open_google_page() throws InterruptedException {
driver.get("http://www.google.com.hk");
searchBox.sendKeys("selenium");
WebElement searchButton = driver.findElement(By.xpath("//*[@id=\"tsf\"]/div[2]/div[3]/center/input[1]"));
searchButton.click();
}
}
3. 运行这个测试,你将看到firebox浏览器被自动启动,然后会自动的输入selenum并搜索。
这样,一个简单的自动化页面测试就完成了。有的朋友可能不太明白这段代码的含义。上面的代码中我标出了红色和蓝色两部分,我简单解释一下。Selenium是通过对浏览器的包装来进行页面处理的,因此我们首先会创建一个与浏览器相关的WebDriver对象。然后我们需要查找页面元素就是通过findeElement的方法和XPath的方式来获取页面对象(红色部分代码)。那么通常我们的一个点击操作产生服务器相应,这里就需要一些时间。蓝色部分的代码就是创建一个等待对象,你可以通过XPath的方式来确定返回后页面上的哪个元素加载完了就认为页面加载完了,同时等待对象也有一个超时设置,这样即是服务器端一直不返回或出错。我们依然可以结束测试。如何更快的确定页面元素的XPath,如下:
selenium是一个自动化测试框架,它拥有IDE和API接口,可以应用于Java, C#. Python, Ruby等语言。用selenium来构建一个自动化的测试程序非常的简单。不过首先你需要熟悉web应用里面的request, response概念,以及XPath的用法。这里我将介绍一下如何利用Junit与selenium来实现自动化页面测试。
1. 下载必要依赖文件selenium-server-standalone-2.25.0.jar, junit-4.7.jar,并将它们放置到工程的lib文件夹下面 (我这里使用Firefox浏览器来作为客户端,所以就不需要下载额外的浏览器执行器,如果你想用IE或是Chrome做客户端,请下载对应的执行器
http://code.google.com/p/selenium/downloads/list)
2. 建立一个测试工程,在工程里创建一个测试文件,并添加如下代码:
import com.thoughtworks.selenium.Selenium;
import junit.framework.TestCase;
import org.junit.After;
import org.junit.Before;
import org.junit.Test;
import org.junit.runner.RunWith;
import org.junit.runners.BlockJUnit4ClassRunner;
import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebDriverBackedSelenium;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.openqa.selenium.internal.WrapsDriver;
import org.openqa.selenium.support.ui.Wait;
import org.openqa.selenium.support.ui.WebDriverWait;
import java.io.IOException;
import static org.openqa.selenium.support.ui.ExpectedConditions.visibilityOfElementLocated;
@RunWith(BlockJUnit4ClassRunner.class)
public class pickTest extends TestCase {
protected static Selenium selenium;
private static WebDriver driver;
@Before
public void createAndStartService() throws IOException {
selenium = new WebDriverBackedSelenium(new FirefoxDriver(), "");
driver = ((WrapsDriver) selenium).getWrappedDriver();
}
@After
public void createAndStopService() {
driver.quit();
}
@Test
public void should_open_google_page() throws InterruptedException {
driver.get("http://www.google.com.hk");
searchBox.sendKeys("selenium");
WebElement searchButton = driver.findElement(By.xpath("//*[@id=\"tsf\"]/div[2]/div[3]/center/input[1]"));
searchButton.click();
}
}
3. 运行这个测试,你将看到firebox浏览器被自动启动,然后会自动的输入selenum并搜索。
这样,一个简单的自动化页面测试就完成了。有的朋友可能不太明白这段代码的含义。上面的代码中我标出了红色和蓝色两部分,我简单解释一下。Selenium是通过对浏览器的包装来进行页面处理的,因此我们首先会创建一个与浏览器相关的WebDriver对象。然后我们需要查找页面元素就是通过findeElement的方法和XPath的方式来获取页面对象(红色部分代码)。那么通常我们的一个点击操作产生服务器相应,这里就需要一些时间。蓝色部分的代码就是创建一个等待对象,你可以通过XPath的方式来确定返回后页面上的哪个元素加载完了就认为页面加载完了,同时等待对象也有一个超时设置,这样即是服务器端一直不返回或出错。我们依然可以结束测试。如何更快的确定页面元素的XPath,如下:
[Selenium自动化测试实战] 不打开浏览器如何进行WEB自动化测试
在一般的使用场景下,使用selenium进行web自动化测试都需要打开一个浏览器的实体,测试脚本通过控制webdriver来对浏览器进行操作。但是在一些场景下测试工程师需要在不打开浏览器的情况下进行自动化测试,也就是以headless的方式运行自动化测试。
?
业界有一些headless的第三方库可以使用,例如大名鼎鼎的PhantomJS。但是这些工具的安装很复杂,同时不一定保证持续的维护。
现在全球最受欢迎的浏览器Chrome在Chrome 59 (Chrome 60 for Windows)版本中已经支持了headless mode,只需要配置一些简单的参数就可以实现。
首先要确认自己机子上的Chrome版本。
require 'selenium-webdriver'
options = Selenium::WebDriver::Chrome::Options.new
options.add_argument('--headless')
options.add_argument('--disable-gpu')
options.add_argument('--remote-debugging-port=9222')
driver = Selenium::WebDriver.for :chrome, options: options
driver.get "https://www.jd.com"
driver.save_screenshot("#{File.dirname(__FILE__)}/#{Time.now.strftime("%F")}")
通过在Selenium::WebDriver::Chrome::Options类的对象中添加argumentoptions.add_argument('--headless'),可以让我们在Chrome在headless模式下运行。
而第二个argument的作用是针对现有bug的work around。第三个argument的作用则是允许我们可以在另外一个浏览器中debug。
为了观测运行的情况,我保存了一个屏幕截图。
相比于之前的headless web自动化方案,Chrome的优势在于设置的方便,甚至可以和当前的框架无缝切换,同时Chrome作为最为主流的浏览器,你也不用担心持续维护的问题。
怎样开始用selenium进行自动化测试
selenium 是一款开源的自动化测试框架,可以有两种开始学习的方式。第一种是使用selenium的IDE进行录制和回放脚本,这个IDE是Firefox的一个插件,网上有很多介绍和下载地址。这一种方式主要是刚接触selenium时,当对selenium的相关原理了解之后,可以开始第二种开始方式,这种方式涉及到代码编写,selenium支持很多种语言作为脚本,本人推荐java或者python。第二种方式主要是根据测试的需要,进行脚本的优化以及测试数据参数化等。
当第二种方式比较熟悉之后,你就可以考虑进行基于selenium的二次开发,形成适合自己的自动化测试框架了。
如何搭建python+selenium自动化测试框架
借花献佛:网页链接
selenium 是一个web的自动化测试工具,不少学习功能自动化的同学开始首选selenium ,相因为它相比QTP有诸多有点:
* 免费,也不用再为破解QTP而大伤脑筋
* 小巧,对于不同的语言它只是一个包而已,而QTP需要下载安装1个多G 的程序。
* 这也是最重要的一点,不管你以前更熟悉C、 java、ruby、python、或都是C# ,你都可以通过selenium完成自动化测试,而QTP只支持VBS
* 支持多平台:windows、linux、MAC ,支持多浏览器:ie、ff、safari、opera、chrome
* 支持分布式测试用例的执行,可以把测试用例分布到不同的测试机器的执行,相当于分发机的功能。
关于selenium的基础知识与java平台的结合,我之前写过一个《菜鸟学习自动化测试》系列,最近学python,所以想尝试一下selenium的在python平台如何搭建;还好这方法的文章很容易,在此将搭建步骤整理分享。
搭建平台windows
准备工具如下:
-------------------------------------------------------------
下载python
-------------------------------------------------------------
如果你是新学python,哪果你没有要用的包是必须依赖于pyhton2.x 的,那么请毫不犹豫的选择python3.5吧!
window安装步骤:
1、下载python安装。
根据自己的操作系统32/64 位,选择相应的版本。
安装过程我就没必要描述,我的安装目录为:C:\Python35
2、进入cmd(windows命令提示符)下面输入"python"命令。
(如果提示python不是内部或外部命令!别急,去配置一下环境变量吧)
修改我的电脑->属性->高级->环境变量->系统变量中的PATH为:
变量名:PATH
变量值:;C:\Python35;C:\Python35\Scripts;
3、安装selenium
3.1、通过pip 安装
C:\Users\fnngj>python3 -m pip install selenium
3.2、通过下载包安装
或者直接下载selenium包:
解压,cmd进入目录:
C:\selenium\selenium2.53.5> python3 setup.py install
===============================================
ubuntu 下安装方式:
1、安装:setuptools
root@fnngj-H24X:~# apt-get install python-setuptools
2、安装pip
root@fnngj-H24X:/home/fnngj/python# tar -zxvf pip-1.4.1.tar.gz
root@fnngj-H24X:/home/fnngj/python# cd pip-1.4.1/
root@fnngj-H24X:/home/fnngj/python# python setup.py install
3、安装selenium
root@fnngj-H24X:/home/fnngj/python/pip-1.4.1# pip install -U selenium
恭喜~! 你前期工作已经做了,上面的步骤确实有些繁琐,但是并不难,不过我们已经完成成了,下面体验一下成果吧! 拿python网站上的例子:
from selenium import webdriverfrom selenium.common.exceptions import NoSuchElementExceptionfrom selenium.webdriver.common.keys import Keysimport timebrowser = webdriver.Firefox() # Get local session of firefoxbrowser.get("hto.com") # Load pageassert "Yahoo!" in browser.titleelem = browser.find_element_by_name("p") # Find the query boxelem.send_keys("seleniumhq" + Keys.RETURN)time.sleep(0.2) # Let the page load, will be added to the APItry:browser.find_element_by_xpath("//a[contains(@href,'httpmhq.org')]")except NoSuchElementException: assert 0, "can't find seleniumhq"browser.close()
(运行过程中如果出现错误:
WebDriverException: Message: u'Unexpected error launching Internet Explorer.
Protected Mode settings are not the same for all zones. Enable Protected Mo
de must be set to the same value (enabled or disabled) for all zones.'
更改IE的internet选项->安全,将Internet/本地Internet/受信任的站定/受限制的站点中的启用保护模式全部去 掉勾,或者全部勾上。)
-----------------------------------------
selenium + python的一份不错文档
===========================如果想通过其它浏览器(IE Chrome)运行脚本=================================
安装Chrome driver
chrome driver的下载地址在这里。
1. 下载解压,你会得到一个chromedriver.exe文件(我点开,运行提示started no prot 9515 ,这是干嘛的?端口9515被占了?中间折腾了半天),后来才知道需要把这家伙放到chrome的安装目录下...\Google\Chrome\Application\ ,然后设置path环境变量,把chrome的安装目录(我的:C:\Program Files\Google\Chrome\Application),然后再调用运行:
# coding = utf-8from selenium import webdriverdriver = webdriver.Chrome()driver.get('http:om')print driver.titledriver.quit()
又报了个错:
Chrome version must be >= 27.0.1453.0\n (Driver info: chromedriver=2.0,platform=Windows NT 5.1 SP3 x86)
说我chrome的版本没有大于27.0.1453.0 ,这个好办,更新到最新版本即可。
安装IE driver
在新版本的webdriver中,只有安装了ie driver使用ie进行测试工作。
ie driver的下载地址在这里,记得根据自己机器的操作系统版本来下载相应的driver。
暂时还没尝试,应该和chrome的安装方式类似。
记得配置IE的保护模式
如果要使用webdriver启动IE的话,那么就需要配置IE的保护模式了。
把IE里的保护模式都选上或都勾掉就可以了。
staf和selenium自动化测试框架的区别
hi
你说这两个框架,都是我以前的老本行了
1、staf是IBM的分布式自动化框架,什么意思呢,分布式就是每台机器都能部署一个STAF进程,然后每个STAF进程都能互相通信,可互相发送指令操作。然后STAF分为内部和外部服务,自己封装的内部服务可以直接使用,外部服务需要你按照他的规则写代码进行接入(java、python、C++之类的)
说实话,STAF现在很少人用了,但是思想还是很好的,值得学习、
2、selenium框架呢,就是一个测试web ui的工具库而已,他提供了与浏览器通信以及操作浏览器控件的功能库
具体再不懂的话,发邮件到test_sunny@hotmail.com找我要QQ或者微信吧