robot framework笔记(二):在RF中自定义chrome启动参数

(一)在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就好了。

相关文章
相关标签/搜索