来自T先生

通过之前的2篇文章,大家都了解了如果利用behave和selenium打开网页和进行基本的操作,但是这些对于项目来说,却是往往不够的。

如果对junit或者TestNG熟悉的人都知道有@Before Class等这些在脚本之前完成的任务:如用户登入,以及当浏览器操作完,关闭浏览器等一些操作。那么问题来了,在behave里面是怎么控制的呢?

在behave中有个environment.py文件,environment.py文件可以很好的解决这个问题,除了解决这个问题,还可以用来解决同一条case可以在不同的浏览器运行的问题。

environment.py文件的介绍

environment.py文件定义了一些当测试脚本在run的过程中之前和之后完成的任务:

before_step(context, step), after_step(context, step)

在这里面的脚本会在每一个步骤之前,之后执行

before_scenario(context, scenario), after_scenario(context, scenario)

在这里面的脚本会在每一个场景之前,之后执行

before_feature(context, feature), after_feature(context, feature)

在这里面的脚本会在每一个feature之前,之后执行

before_tag(context, tag), after_feature(context, tag)

在脚本里面可以设置tag(这个之后会介绍),这里面的脚本会在含有tag的模块里面之前,之后执行

before_all(context), after_all(context)

这里面的脚本会在整个脚本开始之前,之后执行  ----- 一般会在这里面添加一些setup的脚本,例如启动浏览器,设置一些变量,连接数据库,关闭浏览器,关闭数据库 等等

那我们接下来来介绍一个简单的例子:

一、还是老规矩在feature文件夹里面新建example03文件夹,然后再新建example03.feature文件,除了这个文件之外,还需要新建environment.py文件:

from selenium import webdriver  
import sys

def
before_all(context):
    reload(sys)
  
 sys.setdefaultencoding('utf-8')
    context.driver =
webdriver.Firefox()
    
def after_all(context):
   
context.browser.close()

二、example03.feature文件的内容如下:

#../feature/example03/example03.feature
    Feature:Search behave
results in baidu
    
    Scenario: Search behave results in baidu
  
     Given Access baidu website
        When  Input behave characters
  
     Then  There are more than 1 results displaying

三、在example03文件夹里面新建steps文件夹,然后在steps文件夹里面新建example03.py文件:

# This Python file uses the following encoding:
utf-8
#../feature/example03/steps/example03.py

from selenium import
webdriver
import time

@Given('Access baidu website')
def
step_impl(context):
  
 context.driver.get("http://www.baidu.com")

@when('Input behave
characters')
def step_impl(context):
    context.ele_input =
context.driver.find_element_by_xpath("//input[@id = 'kw']")
  
 context.ele_input.send_keys("behave")
    context.ele_btn =
context.driver.find_element_by_xpath("//input[@id = 'su']")
  
 context.ele_btn.click()
    time.sleep(10)
    
@Then('There are more
than 1 results displaying')
def step_impl(context):
  
 context.ele_results =
context.driver.find_element_by_css_selector("div.nums")
  
 context.expected_results = '相关结果'
    if context.expected_results in
context.ele_results.text:
        assert True
    else:
        assert
False

这一章简单介绍environment.py文件的作用,这个文件的作用非常强大。

问题:

在我的脚本里面有个不好的地方是 time.sleep(10), 这个地方就是让线程停止10s. 其实这里应该的做法是写一个显示等待的脚本。 如下:

context.ele_results = WebDriverWait(context.driver, 60).until(
           
EC.presence_of_element_located((By.CSS_SELECTOR, "div.nums")))

如果出一些错误,那是因为你没有把包给加进去的原因, 把下面的代码加到程序的开头部分,就可以了。

from selenium.webdriver.support.ui import WebDriverWait
from
selenium.webdriver.support import expected_conditions
from
selenium.webdriver.common.by import By

Behave + Selenium(Python) 三的更多相关文章

  1. Behave + Selenium(Python) 四

    来自T先生 今天我们开始讲讲behave的厉害的地方. Tag文件的使用 在behave里面,如何来控制哪些case需要run,哪些case不需要run,这个时候就用Tag来控制.好了,接下来我用Ta ...

  2. Behave + Selenium(Python) 二

    介绍feature, py文件和之间关系: example01.feature文件包括5行: Feature行: 介绍这个feature用来干什么的: Scenario行:介绍这个scenario用来 ...

  3. Behave + Selenium(Python)一:

    Behave 介绍:(来自T先生) 最近一个项目用了behave来做测试,因为之前没有接触过,所以写下最近的心得总结. 做自动化的人估计对selenium已经不是很陌生了,但是对于Behave工具,估 ...

  4. selenium+python环境的搭建的自动化测试

    一.安装python: 我安装的是2.7.13版本的:可以在CMD下 运行python命令查看是否安装python,以及安装版本: 在https://www.python.org/getit/这个地址 ...

  5. selenium python 一些操作和定位收集

    (—)滚动条操作 python中selenium操作下拉滚动条方法汇总 selenium_webdriver(python)控制浏览器滚动条 selenium+Python(select定位) Sel ...

  6. python爬虫积累(一)--------selenium+python+PhantomJS的使用(转)

    阅读目录 一.Selenium介绍 二.爬虫为什么要用selenium? 三.PhantomJS介绍 四.PhantomJS安装 五.操作实战 六.在此推荐虫师博客的学习资料 selenium + p ...

  7. 自动化测试基础篇--Selenium Python环境搭建

    学习selenium python需要的工具: 1.浏览器 2.Python 3.Selenium 4.FireBug(Firefox) 5.chromedriver.IEDriverServer.g ...

  8. python爬虫积累(一)--------selenium+python+PhantomJS的使用

    最近按公司要求,爬取相关网站时,发现没有找到js包的地址,我就采用selenium来爬取信息,相关实战链接:python爬虫实战(一)--------中国作物种质信息网 一.Selenium介绍 Se ...

  9. 引用 自动化测试基础篇--Selenium Python环境搭建

    原文链接:https://www.cnblogs.com/sanzangTst/p/7452922.html 鸣谢参藏法师. 学习selenium python需要的工具: 1.浏览器 2.Pytho ...

随机推荐

  1. Tsung 初步介绍安装

    tsung是erlang的一个开源的一个压力测试工具,可以测试包括HTTP, WebDAV, Mysql, PostgreSQL, LDAP, and XMPP/Jabber等服务器.针对 HTTP ...

  2. PowerBuilder -- 调试(Debug)

    @.进入代码调试,执行下一步直接就退出了调试 原文:http://bbs.csdn.net/topics/390126005 处理方法:尝试把 Watch 中查看的变量全部删掉.

  3. 设计模式系列一创建型模式之(简单工厂VS工厂方法)

    1.简单工厂简介 诞生背景:在我们平常编程当中,经常会使用new进行实例化一个对象,此时该类完全依赖于该对象,专业术语来说就是耦合度高.当需求发生变化时我们不得不去修改此类的源码,造成整个系统难以维护 ...

  4. 九度OJ 1057:众数 (基础题)

    时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:8431 解决:2819 题目描述: 输入20个数,每个数都在1-10之间,求1-10中的众数(众数就是出现次数最多的数,如果存在一样多次数的 ...

  5. git拉取远程分支到本地分支或者创建本地新分支

    git fetch origin branchname:branchname 可以把远程某各分支拉去到本地的branchname下,如果没有branchname,则会在本地新建branchname g ...

  6. 在WePY中实现了小程序的组件化开发,组件的所有业务与功能在组件本身实现,组件与组件之间彼此隔离,上述例子在WePY的组件化开发过程中,A组件只会影响到A所绑定的myclick

    wepyjs - 小程序组件化开发框架 https://tencent.github.io/wepy/document.html#/?id=%e5%be%ae%e4%bf%a1%e5%b0%8f%e7 ...

  7. python cookbook第三版学习笔记三:列表以及字符串

    过滤序列元素: 有一个序列,想从其中过滤出想要的元素.最常用的办法就是列表过滤:比如下面的形式:这个表达式的意义是从1000个随机数中选出大于400的数据 test=[] for i in range ...

  8. iOS Dev (53) 修复UIImagePickerController偷换StatusBar颜色的问题

    版权声明:本文为 CSDN 博主 大锐哥(ID 为 prevention)原创文章,未经博主同意不得转载. https://blog.csdn.net/prevention/article/detai ...

  9. ABAP-创建货源清单

    CALL FUNCTION 'ME_DIRECT_INPUT_SOURCE_LIST' *&-------------------------------------------------- ...

  10. JSP&Servlet(转)

    第一篇:Web应用基础1.概念:  1.1应用程序分类     a.桌面应用程序:一般是指采用client/server即客户机/服务器结构的应用程序.     b.web应用程序:一般是指采用Bro ...