(一)在RF中自定义chrome启动参数python
这里主要是实现下面2个功能web
一、禁用chrome正受自动测试软件控制的提示chrome
二、设置默认的下载路径(一些导出、下载类的功能,将文件下载到指定路径下)浏览器
自定义一个关键字测试
from selenium.webdriver.chrome.options import Options class MyKeyword(): def get_chrome_options(self,downloads_path): ''' 自定义chrome启动参数 :param downloads_path: 设置默认的文件下载路径 :return: ''' chrome_options = Options() prefs = { "download.default_directory":str(downloads_path), } chrome_options.add_experimental_option('prefs',prefs) #设置默认的文件下载路径 chrome_options.add_argument('disable-infobars') #chrome76如下禁用chrome受自动软件控制 #下面2行chrome76及以上禁用chrome受自动软件控制 chrome_options.add_experimental_option("useAutomationExtension", False) chrome_options.add_experimental_option("excludeSwitches", ["enable-automation"]) return chrome_options
在RF的登陆中引用这个自定义的关键字,执行的时候若是提示找不到关键字GET CHROME OPTIONS,加一个环境变量PYTHONPATH, value就是python project的路径。ui
*** Settings *** Library SeleniumLibrary Library mykeyword.mykeyword.MyKeyword Suite Teardown CLOSE BROWSER *** Variables *** ${browser} Chrome ${login_url} https://account.cnblogs.com/signin *** Test Cases *** 登陆-XXXXXX 登陆-打开浏览器并进入登陆页面 *** Keywords *** 登陆-打开浏览器并进入登陆页面 ${options}= GET CHROME OPTIONS D:/projectname/testdata/downloads CREATE WEBDRIVER ${browser} chrome_options=${options} GO TO ${login_url} SET SELENIUM IMPLICIT WAIT 10 MAXIMIZE BROWSER WINDOW
总体的目录结构以下:url
(二)若是要在实际项目中使用selenium gridspa
若是要在实际项目中使用selenium gird,能够在上面的基础上稍微修改下。这里必须在继承SeleniumLibrary库的基础上进行修改,我再下篇说明吧。code
(三)python 的pythonpathblog
最后简单说明下,python有个搜索路径的概念,若是提示no keyword,而你又确实写了这个关键字,那么多是库不在python的搜索路径里面。
经过 import sys sys,path 能够看到本身的搜索路径有哪些。
没有的话就新建一个环境变量,名称:PYTHONPATH 值:工程的路径。 环境变量加好后,重启下IDE就好了。