你在做下面的练习之前应该具备
安装好chrome,并通过chrome://version确认其版本号
安装chromedriver并与你的chrome版本相匹配,下载路径如下
https://registry.npmmirror.com/binary.html?path=chromedriver/
你应该有一个python+ide(如pycharm)的环境,反正下面的示例是用这些来完成的。
下好requests库,对语法不再阐述
本质上是个web server
在命令行启动chromedriver应该是如下提示
cmd>chromedriver.exe
Starting ChromeDriver 100.0.4896.20 (f9d71f93d32a6487809d6f35a9670c879fe97dfe-refs/branch-heads/4896@{#203}) on port 9515
Only local connections are allowed.
Please see https://chromedriver.chromium.org/security-considerations for suggestions on keeping ChromeDriver safe.
ChromeDriver was started successfully.
放在那里不要关闭哦~
参阅:6.5的endpoint部分
https://w3c.github.io/webdriver/#endpoints
我就不封装了,你有兴趣自行封装
| Method | URI Template | Command |
|---|---|---|
| POST | /session | New Session |
示例代码:以chrome为例
import requests
server_url = 'http://127.0.0.1:9515/session'
session_data = {
'desiredCapabilities':{
"caps":{"browserName":"chrome"} #此处可以变更浏览器类型,前提你启动了对应的chromedriver或者geckodriver等。
}
}
session_req = requests.post(url=server_url,json=session_data) #json传递
是不是相当于selenium的api
from selenium import webdriver
driver = webdriver.Chrome()
区别是?不需要安装selenium就可以通过api来调用了,当然会更麻烦,人家给你封装好了。
| Method | URI Template | Command |
|---|---|---|
| POST | /session | New Session |
| POST | /session/{session id}/url | Navigate To |
示例代码
import requests
from time import sleep
server_url = 'http://127.0.0.1:9515/session' #这个url不能以/结尾
session_data = {
'desiredCapabilities':{
"caps":{"browserName":"chrome"}
}
}
session_req = requests.post(url=server_url,json=session_data) #此处不能是data
# 打开网址
session_id = session_req.json().get('sessionId') #首先要获取sessionId,是后面操作的根基
dest_url = 'http://121.41.14.39:8088/index.html#/' #比如你要打开这个网址
get_url_data = {'url':dest_url} #字典形式
requests.post(server_url+'/'+session_id+'/url',json=get_url_data) #注意url的格式,跟ep对比
是不是类似于selenium中的driver.get()
| Method | URI Template | Command |
|---|---|---|
| POST | /session | New Session |
| POST | /session/{session id}/url | Navigate To |
| POST | /session/{session id}/element | Find Element |
| POST | /session/{session id}/element/{element id}/click | Element Click |
| POST | /session/{session id}/element/{element id}/value | Element Send Keys |
示例代码
import requests
from time import sleep
#登录
# 1. 打开浏览器
server_url = 'http://127.0.0.1:9515/session' #这个url不能以/结尾
session_data = {
'desiredCapabilities':{
"caps":{"browserName":"chrome"}
}
}
session_req = requests.post(url=server_url,json=session_data) #此处不能是data
# 2. 输入网址
session_id = session_req.json().get('sessionId')
dest_url = 'http://106.14.1.150:8090/forum.php' #这是我在阿里云部署的一个服务器
get_url_data = {'url':dest_url}
requests.post(server_url+'/'+session_id+'/url',json=get_url_data)
# 简单封装下
def get_eid(url,sid,method,method_value): #获取elementid
data = {'using':method,'value':method_value}
return requests.post(url+'/'+sid+'/element',json=data).json().get('value').get('ELEMENT')
def input_text(url,sid,eid,text): #在指定的元素上输入内容
data = {'value':[text]}
requests.post(url+'/'+sid+'/element/'+eid+'/value', json=data)
def click_element(url,sid,eid): #点击指定的元素
requests.post(url + '/' + sid + '/element/' + eid + '/click')
# 3. 输入用户名
# 3.1 获取用户名元素的elementid,通过id方式,其值为ls_username
username_id = get_eid(server_url,session_id,'id','ls_username')
input_text(server_url,session_id,username_id,'ruru023')
sleep(2)
# 3.2 获取密码元素的elementid,通过id方式,其值为ls_password
password_id = get_eid(server_url,session_id,'id','ls_password')
input_text(server_url,session_id,password_id,'123456')
sleep(2)
# 3.3 获取登录按钮元素的elementid,通过css selector方式,其值为.pn.vm
login_button_id = get_eid(server_url,session_id,'css selector','.pn.vm')
click_element(server_url,session_id,login_button_id)
类似于seleniumapi中的
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
在控制台中反复尝试之后,我想到了这种方法,可以按发生日期对类似activerecord的(Mongoid)对象进行分组。我不确定这是完成此任务的最佳方法,但它确实有效。有没有人有更好的建议,或者这是一个很好的方法?#eventsisanarrayofactiverecord-likeobjectsthatincludeatimeattributeevents.map{|event|#converteventsarrayintoanarrayofhasheswiththedayofthemonthandtheevent{:number=>event.time.day,:event=>ev
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
这是一道面试题,我没有答对,但还是很好奇怎么解。你有N个人的大家庭,分别是1,2,3,...,N岁。你想给你的大家庭拍张照片。所有的家庭成员都排成一排。“我是家里的friend,建议家庭成员安排如下:”1岁的家庭成员坐在这一排的最左边。每两个坐在一起的家庭成员的年龄相差不得超过2岁。输入:整数N,1≤N≤55。输出:摄影师可以拍摄的照片数量。示例->输入:4,输出:4符合条件的数组:[1,2,3,4][1,2,4,3][1,3,2,4][1,3,4,2]另一个例子:输入:5输出:6符合条件的数组:[1,2,3,4,5][1,2,3,5,4][1,2,4,3,5][1,2,4,5,3][
我已经构建了一些serverspec代码来在多个主机上运行一组测试。问题是当任何测试失败时,测试会在当前主机停止。即使测试失败,我也希望它继续在所有主机上运行。Rakefile:namespace:specdotask:all=>hosts.map{|h|'spec:'+h.split('.')[0]}hosts.eachdo|host|begindesc"Runserverspecto#{host}"RSpec::Core::RakeTask.new(host)do|t|ENV['TARGET_HOST']=hostt.pattern="spec/cfengine3/*_spec.r
我们的git存储库中目前有一个Gemfile。但是,有一个gem我只在我的环境中本地使用(我的团队不使用它)。为了使用它,我必须将它添加到我们的Gemfile中,但每次我checkout到我们的master/dev主分支时,由于与跟踪的gemfile冲突,我必须删除它。我想要的是类似Gemfile.local的东西,它将继承从Gemfile导入的gems,但也允许在那里导入新的gems以供使用只有我的机器。此文件将在.gitignore中被忽略。这可能吗? 最佳答案 设置BUNDLE_GEMFILE环境变量:BUNDLE_GEMFI
这似乎非常适得其反,因为太多的gem会在window上破裂。我一直在处理很多mysql和ruby-mysqlgem问题(gem本身发生段错误,一个名为UnixSocket的类显然在Windows机器上不能正常工作,等等)。我只是在浪费时间吗?我应该转向不同的脚本语言吗? 最佳答案 我在Windows上使用Ruby的经验很少,但是当我开始使用Ruby时,我是在Windows上,我的总体印象是它不是Windows原生系统。因此,在主要使用Windows多年之后,开始使用Ruby促使我切换回原来的系统Unix,这次是Linux。Rub
1.错误信息:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:requestcanceledwhilewaitingforconnection(Client.Timeoutexceededwhileawaitingheaders)或者:Errorresponsefromdaemon:Gethttps://registry-1.docker.io/v2/:net/http:TLShandshaketimeout2.报错原因:docker使用的镜像网址默认为国外,下载容易超时,需要修改成国内镜像地址(首先阿里
本文主要介绍在使用Selenium进行自动化测试或者任务时,对于使用了iframe的页面,如何定位iframe中的元素文章目录场景描述解决方案具体代码场景描述当我们在使用Selenium进行自动化测试的时候,可能会遇到一些界面或者窗体是使用HTML的iframe标签进行承载的。对于iframe中的标签,如果直接查找是无法找到的,会抛出没有找到元素的异常。比如近在咫尺的例子就是,CSDN的登录窗体就是使用的iframe,大家可以尝试通过F12开发者模式查看到的tag_name,class_name,id或者xpath来定位中的页面元素,会抛出NoSuchElementException异常。解决
最近在学习CAN,记录一下,也供大家参考交流。推荐几个我觉得很好的CAN学习,本文也是在看了他们的好文之后做的笔记首先是瑞萨的CAN入门,真的通透;秀!靠这篇我竟然2天理解了CAN协议!实战STM32F4CAN!原文链接:https://blog.csdn.net/XiaoXiaoPengBo/article/details/116206252CAN详解(小白教程)原文链接:https://blog.csdn.net/xwwwj/article/details/105372234一篇易懂的CAN通讯协议指南1一篇易懂的CAN通讯协议指南1-知乎(zhihu.com)视频推荐CAN总线个人知识总