Behave + Selenium(Python) 四
来自T先生
今天我们开始讲讲behave的厉害的地方。
Tag文件的使用
在behave里面,如何来控制哪些case需要run,哪些case不需要run,这个时候就用Tag来控制。好了,接下来我用Tag文件来实现同一个脚本可以用firefox,chrome和ie三种不同的浏览器来测试。
一、在feature文件里面新建example04文件,然后新建environment.py文件,代码如下:
from selenium import webdriver
import sys
def
before_all(context):
reload(sys)
sys.setdefaultencoding('utf-8')
context.baidu_url =
'http://www.baidu.com'
def before_tag(context, tag):
if
tag.startswith("browser."):
browser_type = tag.replace("browser.",
"", 1)
if browser_type == "firefox":
context.driver =
webdriver.Firefox()
elif browser_type == "chrome":
context.driver = webdriver.Chrome()
else:
context.driver = webdriver.Ie()
def after_tag(context, tag):
context.driver.close()
二、在example04文件夹里面新建example04.feature文件,代码如下:
Feature:Search behave results in baidu
@browser.firefox
Scenario: Search behave results in baidu with firefox
browser
Given Access baidu website
When Input behave
characters
Then There are more than 1 results displaying
@browser.chrome
Scenario: Search behave results in baidu with
chrome browser
Given Access baidu website
When Input
behave characters
Then There are more than 1 results displaying
@browser.ie
Scenario: Search behave results in baidu with ie
browser
Given Access baidu website
When Input behave
characters
Then There are more than 1 results displaying
三、在example04文件夹里面新建steps文件夹,然后在steps文件夹里面新建example04.py, 代码如下:
# This Python file uses the following encoding: utf-8
#../feature/example04/steps/example04.py
from selenium import
webdriver
from selenium.webdriver.support.ui import WebDriverWait
from
selenium.webdriver.support import expected_conditions
from
selenium.webdriver.common.by import By
@Given('Access baidu
website')
def step_impl(context):
context.driver.get(context.baidu_url)
@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()
@Then('There are more than 1 results
displaying')
def step_impl(context):
context.sign_link =
WebDriverWait(context.driver, 60).until(
expected_conditions.presence_of_element_located((By.CSS_SELECTOR,
"div.nums")))
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
四、打开cmd,cd到相应的路径,然后输入behave,你会发现代码分别会在firefox, chrome和IE中分别执行。
但是如果你想要只在firefox中执行,你可以使用命令 behave
--tags=browser.firefox,然后你会发现仅仅打开了firefox。
扩展: 通过tag, 你可以给一个scenario加上N个tag, 每个tag之间用空格隔开就ok,
这样的的话你也可以给scenario加上regression使其变成回归测试的。
除了给scenario加上tag,你还可以给feature加上tag.
behave的脚本都是会把所有的feature文件放在同一个feature文件夹目录下面,然后会在steps里面放所有feature文件对应的py文件。
然后最终的基本目录是这样子的。

Behave + Selenium(Python) 四的更多相关文章
- Behave + Selenium(Python) 三
来自T先生 通过之前的2篇文章,大家都了解了如果利用behave和selenium打开网页和进行基本的操作,但是这些对于项目来说,却是往往不够的. 如果对junit或者TestNG熟悉的人都知道有@B ...
- Behave + Selenium(Python) 二
介绍feature, py文件和之间关系: example01.feature文件包括5行: Feature行: 介绍这个feature用来干什么的: Scenario行:介绍这个scenario用来 ...
- Behave + Selenium(Python)一:
Behave 介绍:(来自T先生) 最近一个项目用了behave来做测试,因为之前没有接触过,所以写下最近的心得总结. 做自动化的人估计对selenium已经不是很陌生了,但是对于Behave工具,估 ...
- selenium+python环境的搭建的自动化测试
一.安装python: 我安装的是2.7.13版本的:可以在CMD下 运行python命令查看是否安装python,以及安装版本: 在https://www.python.org/getit/这个地址 ...
- selenium python grid
学习自动化一直都是在本机操作,感觉这样能够减少工作量确实很少.最近研究了一下分布式操作. 开始的想法是,我在一台机器上启动脚本,然后让脚本在不同机器的不同版本的浏览器上进行跑脚本. 需要准备的东西: ...
- python爬虫积累(一)--------selenium+python+PhantomJS的使用(转)
阅读目录 一.Selenium介绍 二.爬虫为什么要用selenium? 三.PhantomJS介绍 四.PhantomJS安装 五.操作实战 六.在此推荐虫师博客的学习资料 selenium + p ...
- 自动化测试基础篇--Selenium Python环境搭建
学习selenium python需要的工具: 1.浏览器 2.Python 3.Selenium 4.FireBug(Firefox) 5.chromedriver.IEDriverServer.g ...
- python爬虫积累(一)--------selenium+python+PhantomJS的使用
最近按公司要求,爬取相关网站时,发现没有找到js包的地址,我就采用selenium来爬取信息,相关实战链接:python爬虫实战(一)--------中国作物种质信息网 一.Selenium介绍 Se ...
- 引用 自动化测试基础篇--Selenium Python环境搭建
原文链接:https://www.cnblogs.com/sanzangTst/p/7452922.html 鸣谢参藏法师. 学习selenium python需要的工具: 1.浏览器 2.Pytho ...
随机推荐
- 【PyCharm编辑器】之引用selenium包提示错误:Unresolved reference 'selenium' less... (Ctrl+F1)
一.现象还原: 当新建.py文件时,需要引用selenium中的方法时,报错,提示红波浪线: Unresolved reference 'selenium' less... (Ctrl+F1) Thi ...
- 深入浅出Stream和parallelStream
https://blog.csdn.net/darrensty/article/details/79283146
- MySQL -- Ubuntu下的操作命令
=======================安装======================参照MySQL官网的步骤:https://dev.mysql.com/doc/mysql-apt-repo ...
- C# Array类的浅复制Clone()与Copy()的差别
1 Array.Clone方法 命名空间:System 程序集:mscorlib 语法: public Object Clone() Array的浅表副本仅复制Array的元素,不管他们是引用类型还是 ...
- pycharm连git和gitee
http://www.cnblogs.com/feixuelove1009/p/5955332.html https://www.58jb.com/html/171.html
- protect,internal的区别
protected: 爷爷有一张银行卡,爸爸可以用,儿子也可以用,隔壁老王不可以用(因为老王跟爷爷没有继承关系) internal: 王总有一张银行卡,秘书可以用,经理可以用,王总儿子不可以用(因为银 ...
- 九度OJ 1055:数组逆置 (基础题)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:7324 解决:3429 题目描述: 输入一个字符串,长度小于等于200,然后将数组逆置输出. 输入: 测试数据有多组,每组输入一个字符串. ...
- java读取TXT文件中的数据
将文件放在一个指定的磁盘目录下: File file = new File("指定的文件路径"); try{ BufferedReader br = new BufferedRea ...
- keras: 在构建LSTM模型时,使用变长序列的方法
众所周知,LSTM的一大优势就是其能够处理变长序列.而在使用keras搭建模型时,如果直接使用LSTM层作为网络输入的第一层,需要指定输入的大小.如果需要使用变长序列,那么,只需要在LSTM层前加一个 ...
- 【Leetcode-easy】Remove Duplicates from Sorted Array
题目要求:删除排好序的含有重复元素的数组.返回去除重复后的数组长度,并更新原始数组.不能使用额外空间. 思路:要不额外的使用内存空间,那么只有遍历数组,count保持下一个不重复的数字,遍历过程中如果 ...