来自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) 四的更多相关文章

  1. Behave + Selenium(Python) 三

    来自T先生 通过之前的2篇文章,大家都了解了如果利用behave和selenium打开网页和进行基本的操作,但是这些对于项目来说,却是往往不够的. 如果对junit或者TestNG熟悉的人都知道有@B ...

  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 grid

    学习自动化一直都是在本机操作,感觉这样能够减少工作量确实很少.最近研究了一下分布式操作. 开始的想法是,我在一台机器上启动脚本,然后让脚本在不同机器的不同版本的浏览器上进行跑脚本. 需要准备的东西: ...

  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. 【Caffe】利用log文件绘制loss和accuracy(转载)

    (原文地址:http://blog.csdn.net/liuweizj12/article/details/64920428) 在训练过程中画出accuracy 和loss曲线能够更直观的观察网络训练 ...

  2. 1213 - Deadlock found when trying to get lock; try restarting transaction

    1213 - Deadlock found when trying to get lock; try restarting transaction 出现这个原因要记住一点就是:innodb的行锁 和解 ...

  3. Tiny语言编译器简单介绍

    1.简单介绍:编译器是将一种语言翻译成还有一种语言的程序.编译器将源程序的代码作为输出,从而产生用目标语言编写的等价程序.比如源码为C/C++等高级语言,那么目标语言就是目标机器的机器代码.也就是能够 ...

  4. 【BZOJ4966】总统选举 线段树+随机化

    [BZOJ4966]总统选举 Description 黑恶势力的反攻计划被小C成功摧毁,黑恶势力只好投降.秋之国的人民解放了,举国欢庆.此时,原秋之国总统因没能守护好国土,申请辞职,并请秋之国人民的大 ...

  5. 我的Java开发学习之旅------>求字符串中出现次数最多的字符串以及出现的次数

    金山公司面试题:一个字符串中可能包含a~z中的多个字符,如有重复,如String data="aavzcadfdsfsdhshgWasdfasdf",求出现次数最多的那个字母及次数 ...

  6. Latex 4: WinEdt 10试用时间限制的破解+注册码激活

    方法1:我发现这个方法1,现在(2018.06.05)在winedt 10.2上已经不能用了,在低版本(10.1及以下版本)上还可以用,所以如果方法1不行,请看方法2. WinEdt 是目前我发现最好 ...

  7. abap 数字移动小游戏

    [转自 http://blog.csdn.net/forever_crazy/article/details/6542507] report ...... selection-screen pushb ...

  8. 使用git连接到Github

    直奔主题,使用git连接到Github步骤如下: 1. 安装git yum install git 或者 sudo get-apt install git git-core 2. 全局配置 git c ...

  9. Linux- 恢复.swp文件

    当我们对Linux文件系统下的文件编辑时,很多新手老手都有可能出现一些失误,在对一个文件编辑或者改动,甚至是不小心按到键盘并没有发现改动到某处时,没有强制退出(:q!)就直接退出,导致文件变成了.sw ...

  10. matlab程序计时

    t1=datetime(); %程序 t2=datetime() totaltime=t2-t1; disp(t2-t1); 或者: tic %代码块 toc disp(['运行时间: ',num2s ...