目录
3.Appium desktop安装(appium server+appium inspector工具)
4.Appium定位方法(appium中无css selector定位)
Client/Server模式,客户端通过WebDriver json wire协议与服务通信,server端是由nodejs开发的http服务,可安装在任何地方,包括远程服务器;appium通过appium-xcuitest-driver来测试iOS设备(需要安装facebook的WDA(webdriver agent)来驱动测试).
WebDriver json wire协议:
webdriver是基于http协议的,第一次连接appium服务的时候会建立一个session会话,并通过post请求发送一个json告知服务端相关的测试信息.
客户端会传递 Desired Capabilities 给 Appium Server 创建一个会话,Appium Server 会调用 appium-uiautomator2-driver 同时将 UiAutomator2 Server 的两个 apk 安装到测试设备上.
1).安装JDK(1.8版本)
2).配置环境变量
a).JAVA_HOME jdk的安装路径;
b).classpath .;%JAVA_HOME%\lib\dt.jar;%JAVA_HOME%\lib\tools.jar;
c).path %JAVA_HOME%\bin;%JAVA_HOME%\jre\bin;
3).javac -version检查是否安装成功.
1).下载SDK后解压
2).配置Android SDK环境变量
a).ANDROID_HOME SDK的安装路径
b).path %ANDROID_HOME%\tools;%ANDROID_HOME%\platform-tools
3).adb回车检查是否安装成功.
1).下载对应系统的安装包 https://github.com/appium/appium-desktop/releases
2).如果不需要appium inspector,可直接通过npm安装appium
npm install -g cnpm --registry=https://registry.npm.taobao.org
cnpm install -g appium
3).运行appium appium
adb shell getprop ro.build.version.release 获取终端安卓系统版本
adb shell pm list packages 获取包名
appPackage app包名
appActivity activity名
查看appPackage和appActivity名:
adb logcat | grep ActivityManager
adb logcat | grep -i displayed
adb shell dumpsys activity activities | grep mFocusedActivity
automationName android默认使用uiautomator2,iOS默认使用XCUITest
noRest/fullReset 是否重置环境
unicodeKeyBoard/resetKeyBoard 输入中文/测试完成后重置输入法
dontStopAppOnReset 首次启动后不停止app(调试脚本时使用)
skipDeviceInitialization 跳过安装及权限设置等操作
By.id("resoure-id属性值")
By.AccessibilityId("content-desc属性值")
By.className("class属性值")
相对路径定位: "//*[@属性名='属性值']"----->"//*[@text='text的属性值']"
多属性精准定位: "//*[@text='text的属性值' and @resource-id='id属性值']"
androidDriver.findElementsByAndroidUIAutomator("new UiSelector().text("河南")");
实现滚动查找元素:"new UiScrollable(
new UiSelector().scrollable(true).instance(0)
).scrollIntoView(
new UiSelector().text('待查找的文本').instance(0)
)"
点击方法 element.click()
清除方法 element.clear()
输入方法 element.senKeys("text")
设置元素的值 element.setValue("text")
获取属性值 element.getAttribute("属性名")
是否可见 element.displayed() 返回true/false
是否可用 element.enabled() 返回true/false
是否被选中 element.isS elected() 返回true/false
获取元素文本 element.text
获取元素坐标 element.location
获取元素尺寸 element.size
TouchAction可用事件
press 手势按下
release 手势抬起,释放
moveTo 移动
tap 点击,轻敲
wait 等待
longPress 长按
cancel 取消
perform 执行
页面加载流程:
title出现-->
dom树出现(presence还不完整)-->
css出现(可见visibility)-->
js出现,js特效执行(可点击clickable)
html是自上而下加载,js文件加载会阻塞html内容的加载,有些使用js异步加载的方式来完成js加载 ;css样式表下载完成后会跟之前的样式表一起进行解析,会对之前的元素重新渲染.
显示等待针对当个元素控件,有些等待较长时间的元素用显示等待,如果用隐式等待,
比如等待20s,则全局的元素在定位报错时都要等待20s才会抛出异常,所以用显示等待.
显示等待需要与ExpectedConditions条件连用
wait=new WebDriverWait(driver,10,500)
wait.until(ExpectedConditions.visibilityOfElementLocated(by)).click();
尽量脚本中都加上,时间设置3~6s,为所有查找元素操作设置缓冲.
driver.manage().timeouts().implicitlyWait(3, TimeUnit.SECONDS);
appium使用uiautomator底层机制来分析抓取toast,并把toast放到控件树中,但toast本身并不属于控件.
toast必须使用xpath定位
//*[@class='android.widget.Toast']
很好奇,就使用rubyonrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提
我正在编写一个包含C扩展的gem。通常当我写一个gem时,我会遵循TDD的过程,我会写一个失败的规范,然后处理代码直到它通过,等等......在“ext/mygem/mygem.c”中我的C扩展和在gemspec的“扩展”中配置的有效extconf.rb,如何运行我的规范并仍然加载我的C扩展?当我更改C代码时,我需要采取哪些步骤来重新编译代码?这可能是个愚蠢的问题,但是从我的gem的开发源代码树中输入“bundleinstall”不会构建任何native扩展。当我手动运行rubyext/mygem/extconf.rb时,我确实得到了一个Makefile(在整个项目的根目录中),然后当
我有一个围绕一些对象的包装类,我想将这些对象用作散列中的键。包装对象和解包装对象应映射到相同的键。一个简单的例子是这样的:classAattr_reader:xdefinitialize(inner)@inner=innerenddefx;@inner.x;enddef==(other)@inner.x==other.xendenda=A.new(o)#oisjustanyobjectthatallowso.xb=A.new(o)h={a=>5}ph[a]#5ph[b]#nil,shouldbe5ph[o]#nil,shouldbe5我试过==、===、eq?并散列所有无济于事。
我有一些Ruby代码,如下所示:Something.createdo|x|x.foo=barend我想编写一个测试,它使用double代替block参数x,这样我就可以调用:x_double.should_receive(:foo).with("whatever").这可能吗? 最佳答案 specify'something'dox=doublex.should_receive(:foo=).with("whatever")Something.should_receive(:create).and_yield(x)#callthere
Sinatra新手;我正在运行一些rspec测试,但在日志中收到了一堆不需要的噪音。如何消除日志中过多的噪音?我仔细检查了环境是否设置为:test,这意味着记录器级别应设置为WARN而不是DEBUG。spec_helper:require"./app"require"sinatra"require"rspec"require"rack/test"require"database_cleaner"require"factory_girl"set:environment,:testFactoryGirl.definition_file_paths=%w{./factories./test/
我遵循MichaelHartl的“RubyonRails教程:学习Web开发”,并创建了检查用户名和电子邮件长度有效性的测试(名称最多50个字符,电子邮件最多255个字符)。test/helpers/application_helper_test.rb的内容是:require'test_helper'classApplicationHelperTest在运行bundleexecraketest时,所有测试都通过了,但我看到以下消息在最后被标记为错误:ERROR["test_full_title_helper",ApplicationHelperTest,1.820016791]test
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden
我已经构建了一些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
我在app/helpers/sessions_helper.rb中有一个帮助程序文件,其中包含一个方法my_preference,它返回当前登录用户的首选项。我想在集成测试中访问该方法。例如,这样我就可以在测试中使用getuser_path(my_preference)。在其他帖子中,我读到这可以通过在测试文件中包含requiresessions_helper来实现,但我仍然收到错误NameError:undefinedlocalvariableormethod'my_preference'.我做错了什么?require'test_helper'require'sessions_hel