为什么监控的时间设置后电脑开机3秒就重启循环又自动跳回原来的样子?

404 Not Found
404 Not Found选择从不关闭监视器关闭硬盘和系统待机,但是有时重新启动后又跳回默认设置~怎么办?_百度知道
选择从不关闭监视器关闭硬盘和系统待机,但是有时重新启动后又跳回默认设置~怎么办?
在开始”-设置-控制面板-电源选项-电源使用方案选择从不关闭监视器关闭硬盘和系统待机,但是有时候在重启计算机后又变回原有的几分钟后关闭监视器关闭硬盘和系统待机。。。如果有...
在开始”-设置-控制面板-电源选项-电源使用方案选择从不关闭监视器关闭硬盘和系统待机,但是有时候在重启计算机后又变回原有的几分钟后关闭监视器关闭硬盘和系统待机。。。如果有时没有注意,离开几分钟后即进入待机模式。。网络断开。。文件停止上传和下载,影响了工作。。就算手动另存为了一个新的使用方案,开机后也容易跳回原有设置。。请问怎样才能锁定自己设定的设置?
答题抽奖
首次认真答题后
即可获得3次抽奖机会,100%中奖。
采纳数:48
获赞数:271
系统bios设置里,也有电源管理选项,看里面是不是设置了节能选项。
采纳数:66
获赞数:193
我的也一样
为你推荐:
其他类似问题
个人、企业类
违法有害信息,请在下方选择后提交
色情、暴力
我们会通过消息、邮箱等方式尽快将举报结果通知您。电脑时钟反复自动跳回过去某一时间,染病毒吗?
1.首先考虑CMOS电池没电了
更换CMOS电池
2.如果更换后依然如故
就是木马所为
3.推荐你使用最好的木马专杀软件
免费的、汉化的AVG Anti-Spyware
他的数据库中的特征码数量是910978
4.Windows清理助手
5.计算机系统时间保护工具:
其他答案(共1个回答)
电池如果用完了就是正常现象。
换一颗,用不了几块钱。
如果没用玩,那么是木马干的。
首先下载USBCleaner6.0
全面查杀,开启监控,保护时间!
360时间保护程序
升级杀毒软件查杀一遍系统.
1.是楼上大家说的主板电池没电。
2.是木马病毒修改的,修改时间是为了使杀毒软件防御性失效。看下有关360,瑞星等软件就知。
每隔1秒钟执行一次.
每次响10下BEEP
有声卡的时候,默认BEEP声音的情况下,响 大约10秒钟,没秒能运行一次BEEP
然后 timer_()运行结束,然...
分辨率的事... 调一下就好了
我刚玩的时候也这样 然后调下分辨率就好了
是软件冲突了
我原来电脑也是这样
电脑还原之后 玩网页游戏
或者看电影 玩单机游戏都会自动弹回桌面 烦人
我什么软件都没开都不行 。, 后来我把QQ
会不会是因为你的系统出现问题?
你可以重新安装系统(不连接网络的情况下),然后再单独设置网络。如此应该可以解决问题。
还有,你的本本的网卡是否出现问题呢?
答: 尖锐湿疣激光后病毒怎么清除
答: 网络保险技术是由国家科技研发人员研究的整套“安全加固系统”对服务器的安全进行维护,抵制黑客,病毒以及蠕虫入侵
答: Lovesan是利用微软的DCOM RPC漏洞(具体描述请参考MS Security Bulletin MS03-026)进行传播的网络蠕虫病毒。
  Love...
有可能搓纸轮需要清洗一下了,如果清洗了还是不行的话,那估计需要更换搓纸组件了
光设置自发光是不能看到这种效果的,正确操作步骤如下:
1:在材质编辑器中选择一个新的材质示例球,将其命名为灯筒(就是你上面那个发光物体).
2:在(明暗基本参数)Shader Basic Parameters展卷栏中设置材质的明暗器为(胶性)Blinn,在(胶性基本参数)Blinn Basic Psrameters展卷栏中设置材质参数(环境光)Amhient,(漫反射光)Diffuse,(高光反射)Specular均为白色,并设置自发光为100.
3:在视图中选中上面物体,在材质编辑器中单击赋予按钮,就可将材质赋予该物体了
把A产品,B产品及C产品的数量相加,和辅助材料的总数相除,求出分配率,然后再用求出的分配率去分别乘以A,B,C三个产品的数量,这样就可以把辅助材料分别分配到三种产品中去了。比如:A产品的数量是50,B产品的数量是70,C产品的数量是80,合计是:200。辅助材料是:40
分配率=40/50+70+80=0.2
A产品分配辅助材料=50*0.2=10
B产品分配辅助材料=70*0.2=14
C产品分配辅助材料=80*0.2=16
有2个拉电子基团啊,怎么稳定,联想一下“五马分尸”~~
考虑是由于天气比较干燥和身体上火导致的,建议不要吃香辣和煎炸的食物,多喝水,多吃点水果,不能吃牛肉和海鱼。可以服用(穿心莲片,维生素b2和b6)。也可以服用一些中药,如清热解毒的。
确实没有偿还能力的,应当与贷款机构进行协商,宽展还款期间或者分期归还; 如果贷款机构起诉到法院胜诉之后,在履行期未履行法院判决,会申请法院强制执行; 法院在受理强制执行时,会依法查询贷款人名下的房产、车辆、证券和存款;贷款人名下没有可供执行的财产而又拒绝履行法院的生效判决,则有逾期还款等负面信息记录在个人的信用报告中并被限制高消费及出入境,甚至有可能会被司法拘留。
第一步:教育引导
不同年龄阶段的孩子“吮指癖”的原因不尽相同,但于力认为,如果没有什么异常的症状,应该以教育引导为首要方式,并注意经常帮孩子洗手,以防细菌入侵引起胃肠道感染。
第二步:转移注意力
比起严厉指责、打骂,转移注意力是一种明智的做法。比如,多让孩子进行动手游戏,让他双手都不得闲,或者用其他的玩具吸引他,还可以多带孩子出去游玩,让他在五彩缤纷的世界里获得知识,增长见识,逐渐忘记原来的坏习惯。对于小婴儿,还可以做个小布手套,或者用纱布缠住手指,直接防止他吃手。但是,不主张给孩子手指上“涂味”,比如黄连水、辣椒水等,以免影响孩子的胃口,黄连有清热解毒的功效,吃多了还可导致腹泻、呕吐。
合肥政务区网络广告推广网络推广哪家公司比较好 一套能在互联网上跑业务的系统,被网络营销专家赞为目前最 有效的网络推广方式!
1、搜索引擎营销:分两种SEO和PPC,即搜索引擎优化,是通过对网站结构、高质量的网站主题内容、丰富而有价值的相关性外部链接进行优化而使网站为用户及搜索引擎更加友好,以获得在搜索引擎上的优势排名为网站引入流量。
良工拥有十多位资深制冷维修工程师,十二年生产与制造经验,技术力量雄厚,配有先进的测试仪器,建有系列低温测试设备,备有充足的零部件,包括大量品牌的压缩机,冷凝器,蒸发器,水泵,膨胀阀等备品库,能为客户提供迅捷,优质的工业冷水机及模温机维修和保养。
楼主,龙德教育就挺好的,你可以去试试,我们家孩子一直在龙德教育补习的,我觉得还不错。
成人可以学爵士舞。不过对柔软度的拒绝比较大。  不论跳什么舞,如果要跳得美,身体的柔软度必须要好,否则无法充分发挥出理应的线条美感,爵士舞也不值得注意。在展开暖身的弯曲动作必须注意,不适合在身体肌肉未几乎和暖前用弹振形式来做弯曲,否则更容易弄巧反拙,骨折肌肉。用静态方式弯曲较安全,不过也较必须耐性。柔软度的锻炼动作之幅度更不该超过疼痛的地步,肌肉有向上的感觉即可,动作(角度)保持的时间可由10馀秒至30-40秒平均,时间愈长对肌肉及关节附近的联结的组织之负荷也愈高。
正在加载...
Copyright &
Corporation, All Rights Reserved
确定举报此问题
举报原因(必选):
广告或垃圾信息
激进时政或意识形态话题
不雅词句或人身攻击
侵犯他人隐私
其它违法和不良信息
报告,这不是个问题
报告原因(必选):
这不是个问题
这个问题分类似乎错了
这个不是我熟悉的地区
相关问答:123456789101112131415每次启动主板BIOS时间和软驱设置被改是为什么?
按时间排序
BIOS没电了换块电池
楼主,你好!
你的情况很可能是给BIOS芯片供电的电池失效了,建议换一颗吧,打开机箱在BIOS芯片旁边有一个与纽扣大小的电池,将其取下换上新的试试,那个电池不会很贵的,一般好点的5元就搞定^_^
禁用软驱应该到BIOS里禁用,选NONO.也就是没有软驱,系统时间的问题可能是你的主板上的电池(电子)没电了,换一颗试试看.进入系统很慢:机器太差,中毒..后台程序太多.系统冲突.如NERO就与酒精冲突,每次刻盘都死.把酒精DEL就没事了.
COMS没电了。换主板电池吧 换块主板电池试试吧 主板BIOS电池没电,不能保存记忆。打开机箱,换下一个小圆片电池,只三元钱。
电脑不启动故障诊治
了解电脑启动的过程
在诸多电脑故障中,无法正常启动是最令用户头痛的事了。笔者长期从事维护电脑的工作,在这个方面积累了一些经验,现在就将这些经验整理归纳出来与朋友们分享。本文将以家用电脑和windows98操作系统为基础,介绍电脑无法正常启动故障的诊治。
要想准确地诊断电脑不启动故障,首先要了解的起动过程,当我们按下电源开关时,电源就开始向主板和其它设备供电,此时电压还没有完全稳定,主板控制芯片组会根据CMOS中的CPU主频设置向CPU发出一个Reset(重置)信号,让CPU初始化,电压完全稳定后,芯片组会撤去Reset信号,CPU马上从地址FFFF0H处执行一条跳转指令,跳到系统BIOS中真正的启动代码处。系统BIOS首先要做的事情就是进行POST(Power On Self Test,加电自检)。POST的主要任务是检测系统中的一些关键设备(电源、CPU芯片、BIOS芯片、定时器芯片、数据收发逻辑电路、DMA控制器、中断控制器以及基本的64K内存和内存刷新电路等)是否存在和能否正常工作,如内存和显卡等。
自检通过后,系统BIOS将查找显示卡的BIOS,由显卡BIOS来完成显示卡的初始化,显示器开始有显示,自此,系统就具备了最基本的运行条件,可以对主板上的其它部分进行诊断和测试,再发现故障时,屏幕上会有提示,但一般不死机,接着系统BIOS将检测CPU的类型和工作频率,然后开始测试主机所有的内存容量,内存测试通过之后,系统BIOS将开始检测系统中安装的一些标准硬件设备,这些设备包括:硬盘、CD-ROM、软驱、串行接口和并行接口等连接的设备,大多数新版本的系统BIOS在这一过程中还要自动检测和设置内存的相关参数、硬盘参数和访问模式等。
标准设备检测完毕后,系统BIOS内部的支持即插即用的代码将开始检测和配置系统中已安装的即插即用设备。每找到一个设备之后,系统BIOS都会在屏幕上显示出设备的名称和型号等信息,同时为该设备分配中断、DMA通道和I/O端口等资源。最后系统BIOS将更新ESCD(Extended System Configuration Data,扩展系统配置数据)。ESCD数据更新完毕后,系统BIOS的启动代码将进行它的最后一项工作,即根据用户指定的启动顺序从软盘、硬盘或光驱启动。
以从C盘启动为例,系统BIOS将读取并执行硬盘上的主引导记录,主引导记录接着从分区表中找到第一个活动分区,然后读取并执行这个活动分区的分区引导记录,而分区引导记录将负责读取并执行IO.SYS,这是Windows最基本的系统文件。IO.SYS首先要初始化一些重要的系统数据,然后就显示出我们熟悉的蓝天白云,在这幅画面之下,Windows将继续进行DOS部分和GUI(图形用户界面)部分的引导和初始化工作,一切顺利结束,电脑正常启动。
根据故障现象诊治
了解电脑启动的过程,故障就好判断了,下面我们就根据故障现象开始诊治了:
现象一:系统完全不能启动,见不到电源指示灯亮,也听不到冷却风扇的声音。这时,基本可以认定是电源部分故障,检查:电源线和插座是否有电、主板电源插头是否连好,UPS是否正常供电,再确认电源是否有故障,最简单的就是替换法,但一般用户家中不可能备有电源等备件,这时可以尝试使用下面的方法(注意:要慎重):
先把硬盘,CPU风扇,或者CDROM连好,然后把ATX主板电源插头用一根导线连接两个插脚(把插头的一侧突起对着自己,上层插脚从左数第4个和下层插脚从右数第3个,方向一定要正确),然后把ATX电源的开关打开,如果电源风扇转动,说明电源正常,否则电源损坏。如果电源没问题直接短接主板上电源开关的跳线,如果正常,说明机箱面板的电源开关损坏。
现象二:电源批示灯亮,风扇转,但没有明显的系统动作。这种情况如果出现在新组装电脑上应该首先检查CPU是否插牢或更换CPU,而正在使用的电脑的CPU损坏的情况比较少见(人为损坏除外),损坏时一般多带有焦糊味,如果刚刚升级了BIOS或者遭遇了CIH病毒攻击,这要考虑BIOS损坏问题(BIOS莫名其妙的损坏也是有的),修复BIOS的方法很多杂志都介绍过就不重复了;确认CPU和BIOS没问题后,就要考虑CMOS设置问题,如果CPU主频设置不正确也会出现这种故障,解决方法就是将CMOS信息清除,既要将CMOS放电,一般主板上都有一个CMOS放电的跳线,如果找不到这个跳线可以将CMOS电池取下来,放电时间不要低于5分钟,然后将跳线恢复原状或重新安装好电池即可;如果CPU、BIOS和CMOS都没问题还要考虑电源问题:PC机电源有一个特殊的输出信号,称为POWER GOOD(PG)信号,如果PG信号的低电平持续时间不够或没有低电平时间,PC机将无法启动。如果PG信号一直为低电平,则PC机系统始终处于复位状态。这时PC机也出现黑屏、无声响等死机现象。但这需要专业的维修工具外加一些维修经验,因此,建议采用替换法;电源没有问题就要检查是否有短路,确保主板表面不和金属(特别是机箱的安装固定点)接触。把主板和电源拿出机箱,放在绝缘体表面,如果能启动,说明主板有短路现象;如果还是不能启动则要考虑主板问题,主板故障较为复杂,可以使用替换法确认,然后更换主板。
现象三:电源指示灯亮,系统能启动,但系统在初始化时停住了,而且可以听到嗽叭的鸣叫声(没有视频):根据峰鸣代码可以判断出故障的部位。
ccid_page/
Award BIOS
1短声:说明系统正常启动。表明机器没有问题。
2短声:说明CMOS设置错误,重新设置不正确选项。
1长1短:说明内存或主板出错,换一个内存条试试。
1长2短:说明显示器或显示卡存在错误。检查显卡和显示器插头等部位是否接触良好或用替换法确定显卡和显示器是否损坏。
1长3短:说明键盘控制器错误,应检查主板。
1长9短:说明主板Flash RAM、EPROM错误或BIOS损坏,更换Flash RAM。
重复短响:说明主板电源有问题。
不间断的长声:说明系统检测到内存条有问题,重新安装内存条或更换新内存条重试。
1短:说明内存刷新失败。更换内存条。
2短:说明内存ECC较验错误。在CMOS 中将内存ECC校验的选项设为Disabled或更换内存。
3短:说明系统基本内存检查失败。换内存。
4短:说明系统时钟出错。更换芯片或CMOS电池。
5短:说明CPU出现错误。检查CPU是否插好。
6短:说明键盘控制器错误。 应检查主板。
7短:说明系统实模式错误,不能切换到保护模式。
8短:说明显示内存错误。显示内存有问题,更换显卡试试。
9短:说明BIOS芯片检验和错误。
1长3短:说明内存错误。内存损坏,更换。
1长8短:说明显示测试错误。显示器数据线没插好或显示卡没插牢。
现象四:系统能启动,有视频,出现故障提示,这时可以根据提示来判断故障部位。下面就是一些常见的故障提示的判断:
一、提示“CMOS Battery State Low”
原因:CMOS参数丢失,有时可以启动,使用一段时间后死机,这种现象大多是CMOS供电不足引起的。
对于不同的CMOS供电方式,采取不同的措施:
1.焊接式电池:用电烙铁重新焊上一颗新电池即可;
2.钮扣式电池:直接更换;
3.芯片式:更换此芯片,最好采用相同型号芯片替换。
如果更换电池后时间不长又出现同样现象的话,很可能是主板漏电,可检查主板上的二极管或电容是否损坏,也可以跳线使用外接电池,不过这些都需要有一定的硬件维修基础才能完成。
二、提示“CMOS Checksum Failure”
CMOS中的BIOS检验和读出错;提示“CMOS System Option Not Set”, CMOS系统未设置;提示“CMOS Display Type Mismatch ”,CMOS中显示类型的设置与实测不一致;提示“CMOS Memory Size Mismatch”,主板上的主存储器与CMOS中设置的不一样;提示“CMOS Time
进BIOS第一项里面找到软驱选项关闭就行Floppy device软驱设备Diskette Drive A: 磁盘驱动器A:如果系统中装有软驱,使用该选项可启用或禁用软盘驱动器
保存设置没有呀按F10保存
感谢您为社区的和谐贡献力量请选择举报类型
经过核实后将会做出处理感谢您为社区和谐做出贡献
确定要取消此次报名,退出该活动?
请输入私信内容:本帖已被设为精华帖!
打造一款快速高效且高度可复用的ios自动化测试工具
(qq群 :)
无需插桩!
高效率,每秒4-5个action!
轻量极简!
先致敬两个开源工具;
swiftmonkey
因其直接使用了 苹果的私有api 如XCEventGenerator.tapAtTouchLocations 故执行速度极快。同时也用类似android monkey的事件生成机制,自身源源不断的产生如 tap,swipe,pinchIn等事件使其对被测app产生了极大的压力
缺点:需要插桩
类似facebook wda的方式,在xcode中执行xcuitest时启动一个监听server,可通过外部发送命令来创建待测app对应session并启动app,同时也实现了dump tree 和依据xpath,id等来定位某个控件并操作这些控件
Fastmonkey
Xcode9.0()
Xcode8.3()
结合两者优点并改造两者,在XCTestWD基础上实现一个server路由,外部命令时可引导启动app 并执行monkey
app插桩增加小手的反馈,可以更直观的看到其点击效率! (可选,实际不插也可monkey)
测试时会保存截图,及appcrash log(此处植入广告!)
1.monkey执行过程中跳出app,如何跳回继续跑monkey
增加一个定时执行的action,检测当前app,如果不是待测则重新launcher(其时更好的应该时reactive,但并没有找到类似api)
public func addXCTestCheckCurrentApp(interval:Int, appname:String, application:XCUIApplication)
addAction(interval:interval){ [weak self] in
let current = XCTestWDFindElementUtils.getAppName(underElement: root!)
let isRunning = application.running
if current == appname && isRunning {
for i in 0 ..& application.alerts.count {
let alert = application.alerts.element(boundBy: i)
application.launch()
self!.sleep(5)
2.登陆等业务流程如何解决
同样增加一个定时的action,检测当某个关键点出现时,往事件队列中插入一个业务事件
public func addXCTestAppLogin(interval:Int, application:XCUIApplication) {
addAction(interval:interval){ [weak self] in
if root != nil{
let usage = "xpath"
let tag = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeTextField"
let element = try? XCTestWDFindElementUtils.filterElement(usingText: usage, withvalue: tag, underElement: root!)
if element != nil {
self?.addXCTestLoginAction(application: application)
}public func addXCTestLoginAction(application:XCUIApplication) {
addAction(){ [weak self] in
if root == nil{
let usage = "xpath"
let username = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeTextField"
let passwd = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeSecureTextField"
let button = "//XCUIElementTypeOther[@name='登录']//XCUIElementTypeStaticText[@name='登录']"
var element = try? XCTestWDFindElementUtils.filterElement(usingText: usage, withvalue: username, underElement: root!)
if let element = element {
let value = "abc"
let semaphore = DispatchSemaphore(value: 0)
let numberOfTaps = 1
self!.sharedXCEventGenerator.tapAtTouchLocations(locations, numberOfTaps: UInt(numberOfTaps), orientation: orientationValue) {
semaphore.signal()
semaphore.wait()
支持控件,点击序列,跳出监控
总运行时间,总点击次数。action固定间隔,action随机间隔(暂时内编码,后续参数化)
增加跳过server 跳过发请求机制,运行xctestwduitest 直接启动待测app直接跑monkey
支持xcode9, ios11
关于登录输入用户密码等的业务操作未来
实现基于控件的monkey
crash收集上报
社区兄弟的搭建扫盲贴
另一扫盲贴
jenkins部署案例
*基于xcode9.2部署
「All right reserved, any unauthorized reproduction or transfer is prohibitted」
如果觉得我的文章对您有用,请随意打赏。您的支持将鼓励我继续创作!
期待开源....
这个图片分类有点牛批
好工具,期待开放
请问能加入业务流程脚本嘛?
业务流程脚本? 比如登陆吗? 如果是跑monkey过程中插入一些特定业务逻辑是可以的。
业务逻辑实际就是原子性的一系列点击输入。 如果是按case跑目前还不支持 改造会比较大 但理论上也是可以的
是这样子,就是比如有业务链路:
a-&b-&d-&c-&a
随机可能做不到。那如果我用脚本把这些链路都写成一个个业务脚本,可以当做插件插到框架中去,随机执行的话,就会更加有效果。
可以的。这个链路执行的时候 ,随机会暂停。执行完随机再继续。只要设置好各个链路的触发点即可。相对于单个链路中的行为不随机,而不同链路之间也是随机的
将本帖设为了精华贴
补充一个业务流程
能并发吗?
其实现在的核心应该还是数据监控和数据分析,执行的话相对还比较好实现一些,期待楼主把未来那块补全,加油
稍微改造下可以的。
膜拜大神,期待开源,牛的一批
高效率,每秒4-5个action!
这块是带截图吗?
idevicescreenshot?
截图没有细研究,目前调试看截图是异步的,跟不上action的速度
那会不会出现,截图看到的,和真实的不是一个地方的现象?
另外想咨询一下:
关于检测是否在指定APP,调用的这个方法,是封装的吗?
具体是会调用哪个API? 或者内部的实现机制是?
let current = XCTestWDFindElementUtils.getAppName(underElement: root!)
目前感觉检测是否指定APP,还挺难实现的。 我看你这个方法,挺好。
打个比方,会出现点击了20次 可能才截出6,7张图。 截图比较鸡肋,实际效果不如录像或者log
自己加了个接口。
这个取得是 xml里
节点属性name
这个func大致实现原理是?
log的话,是采用idevicesyslog来收集还是?
录屏是用什么方案
重新launcher。
这块是用的什么方法?
我之前有使用过:idevicedebug 方法
重新launcher 就调的 XCUIApplication.launch()
但这样会重启app,我希望能后台切回前台是最好的。
见 官方api
感觉应该用 activate() 但目前只是beta的
log的 就记录每个action后 点击什么页面什么位置。
已完成 基于控件的点击,解析出所有控件,随机某个控件点其中心点 。每秒大概3-4个action
log的 就记录每个action后 点击什么页面什么位置。
点击什么页面,这个是如何定义页面这个概念的?
iOS端毕竟没有Android端activity
取title辅助定位就行。appname会引起个问题,那个函数要重写了
取title辅助定位,是指类似dump出xml后,然后取里面的title?
这里面有没有什么规则? 如取几个,或者去布局的几个等?
有没有验证过,定义window后的准确率有多高? 即,进入相似页面,或者滑动后,是否认为是同一个页面。
了解了,多谢。
xctestwd里已有api取title
37Floor has been deleted
请问XCEventGenerator这个API怎么获得啊~~~我在iOS-Runtime-Headers里面没找到,求大神分享一下
另外 oc的 wda提供了
楼主太棒啦
但是第二个地址报404不知道是怎么回事~~~
虽然做伸手党有点可耻,但是我还是想问楼主这么强大的工具什么时候开源给大家用啊~~~~~
41Floor has been deleted
404 那个发帖时链接多了个( ,不明所以。。
这个仅仅是api简易说明。google搜搜就有了
application.running , XCUIApplication 好像没有这个吧...
注! 熊猫直播测试组 出品; 玩游戏关注熊猫直播
已开源了1.0.0.1002。
尚有瑕疵,望见谅。
运行说明:
build 配置 类似wda
启动server前
执行 iproxy
做手机与mac的端口映射
在xcode中的XCTestWDUITests target 里执行 run the test case 启动server,开始监听8001端口
执行 ‘curl -X POST -H "xx"
-d "xx" http ://127.0.0.1:8001/wd/hub/monkey’ ,开始执行monkey
XCTestWDMonkeyController.swift
let monkey = Monkey(frame: app.frame)
monkey.addDefaultXCTestPrivateActions()
monkey.addXCTestTapAlertAction(interval: 100, application: app)
monkey.addXCTestCheckCurrentApp(interval: 10, application: app)
# app后台或退出检测
//monkey.addXCTestAppLogin(interval: 50, application: app)
# 登陆业务逻辑
50次事件加入1次业务关键点检查,无登陆逻辑可注释
monkey.monkeyAround()
MonkeyXCTestPrivate.swift public func addDefaultXCTestPrivateActions() {
addXCTestTapAction(weight: 35)
#随机点击事件
100-200ms/action
//addXCTestElementTapAction(weight: 10)
#基于控件的点击事件
执行概率: 10/(35+10+5)
300-400ms/action
addXCTestLongPressAction(weight: 1)
addXCTestDragAction(weight: 1)
addXCTestPinchCloseAction(weight: 1)
addXCTestPinchOpenAction(weight: 1)
addXCTestRotateAction(weight: 1)
注!事件序列如何实现:
通过设置一个关键点 引入一个事件序列,当检测到出现关键点时插入自定义事件序列,并立即执行;
可按此原理实现自己的事件序列
public func addXCTestAppLogin(interval:Int, application:XCUIApplication) {
addAction(interval:interval){ [weak self] in
let session = try XCTestWDSessionManager.singleton.checkDefaultSessionthrow()
#检测到出现'登录'关键点时 插入
let root = session.application
if root != nil{
let usage = "xpath"
let tag = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeTextField"
let element = try? XCTestWDFindElementUtils.filterElement(usingText: usage, withvalue: tag, underElement: root!)
if let element = element {
if element != nil {
self?.addXCTestLoginAction(application: application)
#插入一个特殊事件序列
public func addXCTestLoginAction(application:XCUIApplication) {
#该事件为一个原子事件序列,保证事件中不会插入其他事件
addAction(){ [weak self] in
let session = try XCTestWDSessionManager.singleton.checkDefaultSessionthrow()
let root = session.application
if root == nil{
let usage = "xpath"
let username = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeTextField"
let passwd = "//XCUIElementTypeOther[@name='登录']/XCUIElementTypeSecureTextField"
let button = "//XCUIElementTypeOther[@name='登录']//XCUIElementTypeStaticText[@name='登录']"
var element = try? XCTestWDFindElementUtils.filterElement(usingText: usage, withvalue: username, underElement: root!)
if let element = element {
if let element = element {
NSLog("XCTestWDSetup-&loginuser find?\(String(describing: element))&-XCTestWDSetup")
let value = ""
let rect = element.wdRect()
let point = CGPoint(x:rect["x"]!,y:rect["y"]!)
let locations = [point]
let semaphore = DispatchSemaphore(value: 0)
let numberOfTaps = 1
self!.sharedXCEventGenerator.tapAtTouchLocations(locations, numberOfTaps: UInt(numberOfTaps), orientation: orientationValue) {
#点击使用坐标,调用xctest私有api
semaphore.signal()
semaphore.wait()
注! 屏幕中控件获取如何加快速度
如果使用 app.descendants(matching: .xxx) 可以获取某种类型的控件集,但获取其中某个控件坐标时,xctest内部会再次执行一次当前界面查找确保控件仍存在,该过程测试时间过长,超过500ms甚至1s更多。故此处进行了优化,缩短了时间 ;最终点击某个控件控制在300-400ms
static func xpathToList(_ root:XCElementSnapshot, _ xpathQuery:String) -& [CGPoint]? {
var mapping = [String:XCElementSnapshot]()
let xml = generateXMLPresentation(root,nil,nil,defaultTopDir,&mapping)?.xml
if xml == nil
{return nil}
let tree = try? XMLDocument(string: xml!, encoding:String.Encoding.utf8)
let nodes = tree?.xpath(xpathQuery)
#筛选生成对应节点
var list = [CGPoint]()
for node in nodes! {
if mapping[node.attr("private_indexPath")!] != nil{
let x = (node.attr("x")! as NSString).floatValue
let y = (node.attr("y")! as NSString).floatValue
if (x &= 0) && (y &= 0)
{continue}
let snapshot = mapping[node.attr("private_indexPath")!]
let isvisible = try? snapshot?.isWDVisible()
#仅isvisible的才视为当前可见,加入到point队列
if isvisible == nil || isvisible! == false
{continue}
let w = (node.attr("width")! as NSString).floatValue
let h = (node.attr("height")! as NSString).floatValue
let cX = Int(x + w/2)
let cY = Int(y + h/2)
let point = CGPoint(x:cX,y:cY)
if list.contains(point) == false {
list.append(point)
return list
#最终返回所选控件对应的坐标队列集
注! app退出如何检测
(坑点!!! app切换或者闪退自身也需要时间,可能获取当前pid时app还未完成退出或切换操作)
app退出通过三种方式检测
1) app退出检测线程 每500ms执行一次, 检测耗时50ms
public func addXCTestCheckCurrentApp(interval:Int, application:XCUIApplication) {
addCheck(interval:interval){ [weak self] in
let work = DispatchWorkItem(qos:.userInteractive){
let isRunning = application.running
#获取当前是否在运行中
let current = Int(XCTestWDFindElementUtils.getAppPid())
#获取当前前台pid
if current != self?.pid || !isRunning{
#当切换到后台或已退出时,执行launch
application.launch()
self?.sleep(5)
self?.pid = Int(XCTestWDFindElementUtils.getAppPid())
DispatchQueue.main.async(execute:work)
static func getAppPid() -& Int32{
var activeApplicationElement:XCAccessibilityElement?
activeApplicationElement = (XCAXClient_iOS.sharedClient() as! XCAXClient_iOS).activeApplications().first
if activeApplicationElement == nil {
activeApplicationElement = (XCAXClient_iOS.sharedClient() as! XCAXClient_iOS).systemApplication() as? XCAccessibilityElement
let pid = activeApplicationElement?.processIdentifier
#通过私有api 获取当前前台pid
if pid == nil{
return pid!
上述检测方式 因为使用xcaxclient私有api和launch 只能在主线程中执行,故只能通过定时方式检测并插入高优先级队列执行。而且要尽量缩短其耗时从而不会影响其他各点击事件的执行频率
2) 低概率检测事件,获取pid前增加延迟
public func addXCTestTapAlertAction(interval: Int, application: XCUIApplication) {
addAction(interval: interval) { [weak self] in
usleep(2000000)
let isRunning = application.running
let current = Int(XCTestWDFindElementUtils.getAppPid())
3) 最后一关把控,当resovle前再检测一次
func resolve() throws {
self._application.query()
let pid = self._application.processID
let activeApplicationElement = (XCAXClient_iOS.sharedClient() as! XCAXClient_iOS).activeApplications().first
let currentprocessID = activeApplicationElement?.processIdentifier
if pid != currentprocessID{
#最后把关 pid不同 则抛出异常
throw OperationError.Error
self._application?.resolve()
此处实现目前仍存在瑕疵,如果app在上述处仍在前台,处却切到后台,monkey可能crash,原因是此时application已不在 _application.resolve崩溃。但当xcode9发布时应该就不存在问题了,新api 提供了state,可以线程检测当前状态
(此崩溃仅会出现在 开启基于的控件点击)
1) 瑕疵修正
2) 性能监控
3) 崩溃分析
4) 控件选择子 算法
我测试这个是可以用,可能没公开。我当时搜google 好像在某个stackoverflow里看到的。
楼主强大 问个问题 就是这个录屏是怎么实现的?是通过screenshort()这个返回的截图合成的视频么
还有一个疑问就是getPageSource()这个拿页面的xml结构的api好慢呀 有没有什么好的办法
录屏我也还没有实现,仅仅是个想法。
你说的getpagesource 是哪个框架的api?
在44楼发了个优化的方案,牺牲一些准确度来提升获取速度。
@感谢楼主回复 getpagesource这个是appium的实际上就是调用的wda的source 取页面的xml结构 因为我现在做了一个事实操控ios的平台 其他部分已经优化了但就是唯独获取页面xml这块 复杂的页面居然要10s 不好意思 还有一个问题 就是XCTestWD貌似要安装两个app 表示没有开发者账号很蛋疼 你这个要安装多少个app呀 在手机上 谢谢
还有一个就是我发现wda的查找控件我一般是根据id 需要1s多 然后点击啥的也要1s多
是的,需要占两个bundle id
我在想一个问题 是不是swift比object-c的效率要高点 我发现相同的操作 wda的运行速度要低于XCTestWD
我一开始就选的wda 所以我现在执行一个action 基本上都要2-3s
真想换成XCTestWD
没有 我看wda,xctestwd代码大致类似。
理论上oc的应该更快些,你那里速度慢 根本原因是用的appium,中间经过了太多过程,比如网络请求
iOS初级用户请教,我在打开XCTestWD.xcodeproj 文件时,提示我下图错误(我的是xcode9 beta5)说是缺少文件,请教如何解决,谢谢~
55Floor has been deleted
我在取xml的时候 是直接通过调用的wda没有经过appium还是差不多慢一点
而且这又有个新的问题 当我用iproxy得时候 映射到本地mac的ip地址是127.0.0.1也就是说 我通本机的ip地址是无法访问的 这个有木有比较好的解决办法呀 对了性能数据的获取我已经做好了 需要的话 可以找我拿
大佬你怎么做的性能数据的获取啊?注入式还是?
是的 直接把代码注入到wda中然后以rest服务的形式发布出来
谢谢楼主回复,我打开后里面还是没找到,我是刚从你的git上clone 下来的,里面没这个文件,能发一个给我吗或者楼主重新传一个到git上,谢谢~
我今天WDA不知道怎么回事报错:
15:23:50.0 XCTRunner[] Running tests...
15:23:50.0 XCTRunner[] Connection peer refused channel request for "dtxproxy:XCTestDriverInterface:XCTestManager_IDEInterface"; channel canceled
Failed to run tests: The operation couldn’t be completed. (DTXProxyChannel error 1.)
大佬知道这个该怎么解决吗?
1.断掉use线 然后重启wda
2.重启手机 重启wda
能解决95%的wda问题
楼主 你的xml是通过sctestwd取得么 怎么取得呀
刚从楼主的git上clone的zip包,报错缺少project.pbxproj 文件,各位大神们,谁有这个文件发一个呗,万分谢谢~邮箱:
所有文件又重新提交了。你再clone试试,应该是环境问题
44楼的 xpathToList
我取的point集合
25楼那个 func 效率低 重写了
我已找到了
XCTestWDXPath 这个类中就有 生成xml的方法 哈哈 好开心
谢谢楼主,还是不行,不知道是不是我的环境问题(我xcode版本Xcode 9 beta 5),还是同样的错误,提示我缺少那个文件,楼主直接发我一个这个文件,我拷贝过来可以用吗?如果可以的话,楼主可以邮件发我下吗?谢谢~麻烦了~ 我邮箱
楼主,我这边遇到了同样的问题,提示
“....Fastmonkey/XCTestWD-master/XCTestWD/XCTestWD.xcodeproj cannot be opened because it is missing its project.pbxproj file.”
刚重新下载,还是不行,在线等~
Xcode 8.3.2
打开同样问题
XCTestWD-master/XCTestWD/XCTestWD.xcodeproj cannot be opened because it is missing its project.pbxproj file.
可能我少传了.. 马上看下
发现那个缺失的文件是写到了 .gitignore 文件里,他已经给复制出来了,其他朋友如果遇到这个问题,可以.gitignore 里找,或者直接clone ,谢谢楼主的积极回复,万分感谢~
感谢 ,已修正了问题。
75Floor has been deleted
我还在晕头中,你已经改好了。
感谢各位大神们,可以打开了!!激动中~
我把项目克隆下来, 发现打不开, 把错误Google了一下, 从原版XCTestWD当中xcodeproj文件的包内容, 复制了一个文件过去, 再重新拉项目文件, 又提示缺东西, 我看又有新的更新, 我pull了就好了, 其他人还说有问题, 然后我发现我修改了xcodeproj文件后git没有提示任何变动, 想了一会才发现是 .gitignore 文件的问题
请问楼主这怎添加
第三方库都用cartfile安装
81Floor has been deleted
application.running 没公开的话,是如何能使用的呢? 你用的是Xcode9?
我的是8.3.3 ,这个试试便知了
谢谢回复,安装好了,再问一下可否做到多台设备一起测试
可以的。但需要代码修改下。
1启动server监听的端口 2iproxy端口 3curl命令请求的端口
有空我再改下,xcodebuild 直接完成 1,2,3 ,这样可以简单对接到jenkins支持多机了
楼主 swift 里面怎么取一个map的value值么
这个语言真的是坑呀
有那么点像python。但!,?,_ 这些并不友好。而且异常捕获也很坑
// 查询字典dict["name"]// 遍历字典中所有的值for value in dict.values {
print(value)}
if mapping[node.attr("private_indexPath")!] != nil{
let snapshot = mapping[node.attr("private_indexPath")!]
参照swiftMonkey的似乎没有限制时长的,我在原地方看到有个扩展方法设置跑的时间
extension Monkey {
func startTesting(forDuration duration: TimeInterval) {
let start = CFAbsoluteTimeGetCurrent() // start time
actRandomly()
actRegularly()
} while ((CFAbsoluteTimeGetCurrent() - start) & duration)
ok这个时长已计划
突然发现xctestwd 不支持utf-8的中文 怎么搞呀
输入中文字符 ?
查询控件的时候
控件的id为中文
let value = request.jsonBody["value"].string 这里取出来的就是???????
request这个里面就已经解析成?了 转码也转不鸟了 我看了下源码 是把所有的存成了Uint8
不知道作者怎么想的
调式下看看 是从哪里开始存成??了。感觉上层macaca也会有获取中文的需求,不应该啊
解析请求的时候 存成了Uint8 这玩意 这玩意存不鸟中文
我明白了。你是说,发给 xctestwd的请求
如 控件的id是个中文。 xctestwd接收到就解析成 uint8了。。
达峰帮看看?
对的 对的 而且能不能把两个应用合成一个呀 没有开发者账号 要是再加一个应用就不行了
clear 清除文本这个方法写的也有问题
哪个clear清除?
你发的请求是什么?
确认的问题请提issue
已在github上提了
(RequestRoute("/wd/hub/session/:sessionId/element/:elementId/clear", "post"), clearText),
这个方法 element?.typeText(“”) 这样是不会清除文本的 我改了下:
let text:String = firstNonEmptyValue(element?.wdValue() as? String, element?.wdLabel()) ?? ""
let l = text.characters.count
var bb = "\u{8}"
var typeString = ""
for _ in 1...l {
typeString=typeString + bb
element?.typeText(typeString)
这样就可以清除了 谢谢
clear的方法麻烦给xctestwd提个merge request
105Floor has been deleted
刚才试了下 最新版的 只test xctestwduitests 只会安装一个应用了
? 我也同步下
中文的还没回复 清除的 看下103楼 目前还发现xpath定位不是很准确
用真机跑可以得到截图和crash日志吗
xcode里点结束时有个日志路径
xxxxx/test/attachments/
包含截图和crash
github上XCTestWD的管理员SamuelZhaoY 这哥们大家遇到么 有点无语呀
你好,我是XCTestWD 的作,对于你提出的部分问题, 因为考虑到实际价值,所以做了bypaas.
只是觉得 应该充分的沟通 这个github 评论模式不太习惯
欢迎钉钉留言 Samuel.蕉庵 +65-, 提交issue 建议提供多的信息, 关于一些想法可以给一些完整的建议,而不是只言片语.
对issue 处理及时,其实在作者的角度已经是对答问者最大的负责.
特别是同时提出4 - 5 个issue 的时候, 不妨先整理一下思绪
115Floor has been deleted
您好 我这边成功用carthage安装了swiftJSON.framework,但是swifter.framework却失败,查看发现git地址已经404了,不知道是该如何解决呢?
github "glock45/swifter" == 1.3.3
试试这个。
成功了!感谢回复
每次执行如下命令后
都会造成如下错误
不知道该如何解决?
monkey 跑起来了吗?
可以把异常断点开下,看看crash在哪里?
运行命令后终端有输出后中途停止在这里了
找到报错的地方是这里
是说 server都没起来吗?
你那里xcode版本是多少的?
先试试xcode中启动 server能运行起来不?
这样是不是运行成功了?
server启来了。
curl -X POST -H "Content-Type:application/json" -d "{\"desiredCapabilities\":{\"deviceName\":\"xxxx\",\"platformName\":\"iOS\", \"bundleId\":\"xxxx\",\"autoAcceptAlerts\":\"false\"}}"
看看monkey能跑起来不?
大神 有如上的报错
没明白他说的找不到的文件是什么??
这步执行过了吗?
显示如上。
这时我应该做什么操作?
我执行了如下命令
就报了最初的错误
执行只需要三步就可
启动server (或xcode中启动) (或xcodebuild) 2选1
3.curl -X POST -H "Content-Type:application/json" -d "{\"desiredCapabilities\":{\"deviceName\":\"xxxx\",\"platformName\":\"iOS\", \"bundleId\":\"xxxx\",\"autoAcceptAlerts\":\"false\"}}"
正常情况 执行完curl app就启来开始跑monkey了
你那里是不是重复启动server了?
132Floor has been deleted
确实是重复启动server了!
但是第二步(xcodebuild)报如下错
我把设备断开连接后重启 再次执行第二步(xcodebuild -project XCTestWD.xcodeproj \
-scheme XCTestWDUITests \
-destination 'platform=iOS,name=我的devicename' \
XCTESTWD_PORT=8001 \
clean test)
后,又报另外的错误!
先用xcode启动的吧。 xcodebuild的回头我看看
跑fastmonkey时,xcode要一直打开么?
如果是用xcodebuild执行, 则不需要xcode
xcodebuild我多试了几次
如上,这种情况就是成功了吧?
然后我执行了第三步后
您知道是什么情况吗??
多试了几次,居然莫名可以跑起来了
你的mac插了多台iphone吗?
如果是的话,iproxy
后需要加serialid 指定哪台iPhone设备做端口映射。 然后curl 中执行对应iPhone设备
只插了一台呢~
我用xcodebuild方式跑起来的截图和crash日志在哪里找呢
xcode里中断运行时 有个log路径的日志输出
xxx/XCTestWD-xxx/Logs/Test/Attentment
您说的这个是在xcode中启动server的时候的方式吧?
我这边想问的是在终端用xcodebuild启动server的那种,结束与获得截图与log的方式?
应该是一样的。同个目录
楼主,我前几天由于工作原因,一直没来得及使用你的,今天git下来体验,run的时候报错:bridging header '/Users/xiatian/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWD/XCTestWD-Bridging-Header.h'不知道是楼主没上传还是要在哪下载呢?
楼主这边提供的没有问题,应该是你的路径错了
我直接git clone 的,接着在路径下carthage update,然后运行xcode打开XCTestWD.xcodeproj,运行,就报这个错误啊~~~
你看下 你工程里应该没有XCtestWD-Bridging-Header.h文件,应该有一个XCTestWDUITests-Bridging-Header.h文件,看它在什么路径下,并在 Build Settings -& Header Search Paths 项里做修改试试
确实没有XCtestWD-Bridging-Header.h文件,在XCTestWDUITests里面有一个XCTestWDUITests-Bridging-Header.h文件
还是报那个错误
xcode buildsetting有问题。
xctestwd中没有用到oc,swift混编,header search path,objecktive-c bridging header 配置可去掉再试试。xctestwduitest中用了混编才需要 xctestwduitest-bridging-header.h
我现在可以在xcode/DerivedData/xxxx/Logs/Test/Attachments 路径里面找到截图,您说的crash log也是会生成在 Attachments文件夹里面吗?
该crash log是否可以追踪到app代码问题?
crash 也在Attachments里
就是系统生成的崩溃堆栈文件,研发有对应的符号文件是可以定位的
中提及了此贴
为了不只做伸手党,我把我的配置过程以及一些遇到的简单问题做了个总结,萌新们可以来看下具体的配置流程,遇到大问题再来问大佬吧~~
iproxy ,iproxy命令怎么安装的?
brew install usbmuxd
多谢,我也刚找到
之前配置的比较乱,打算重新配置下,结果遇到了这个问题,尝试解决未成功...
重装下那个 fuzi
登录这块的用户名和密码如何配置?iOS代码没去学习过,看的不是太懂。。。- -
自己重新carthage update了很多次都没解决原来是 cezheng/Fuzi 版本的问题,之前1.0.1一直失败。
请问Monkey时间设定的功能快完成了吗,小白伸手党万分感谢
这个还没有上日程。。有其他 job 要先弄
登录的 可以先看看 44楼
懂了,设计的很好,自定义事件处理,赞
你说的时间设定 是指 设 monkey最多跑多久吧?
就是给monkey设定运行时间,例如在如下命令行里添加 time = 1000s 一项,它就会自动在1000秒时停止monkey.
curl -X POST -H "Content-Type:application/json" -d "{\"desiredCapabilities\":{\"deviceName\":\"xxxx\",\"platformName\":\"iOS\", \"bundleId\":\"xxx\",\"autoAcceptAlerts\":\"false\"}}"
18:03:52.821 xcodebuild[6] Error Domain=IDETestOperationsObserverErrorDomain Code=4 "Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/xxxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Logs/Test/932A09AF-A07A-45B2-BBDB-42CAE9A7F4C5/Session-XCTestWDUITests-_180350-vRucrT.log" UserInfo={NSLocalizedDescription=Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/xxxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Logs/Test/932A09AF-A07A-45B2-BBDB-42CAE9A7F4C5/Session-XCTestWDUITests-_180350-vRucrT.log}Testing failed:
Command /bin/sh failed with exit code 127** TEST FAILED **The following build commands failed:
PhaseScriptExecution Run\ Script /Users/xxxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.sh
请问这个错误怎么处理
这段Log 没有什么有用的信息,没能看出是什么错误,再详细描述下?
评论都看了 其中出现的错误也都改了 然后run的时候 报这个
不知道怎么
export XCODE_APP_SUPPORT_DIR=/Applications/Xcode.app/Contents/Developer/Library/Xcode
export XCODE_PRODUCT_BUILD_VERSION=8E3004b
export XCODE_VERSION_ACTUAL=0833
export XCODE_VERSION_MAJOR=0800
export XCODE_VERSION_MINOR=0830
export XCTESTWD_PORT=8001
export XPCSERVICES_FOLDER_PATH=XCTestWDUITests.xctest/XPCServices
export YACC=yacc
export arch=armv7export YACC=yacc
export arch=armv7
export diagnostic_message_length=116
export variant=normal
/bin/sh -c /Users/xxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.shd2af20afea33edcaf515e/Users/xxxxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.sh: line 12: ideviceinstaller: command not foundCommand /bin/sh failed with exit code 127 18:15:54.733 xcodebuild[7] Error Domain=IDETestOperationsObserverErrorDomain Code=4 "Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/jxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Logs/Test/F063AE42-B5A6-41C3848607/Session-XCTestWDUITests-_181552-bw8Dwx.log" UserInfo={NSLocalizedDescription=Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/xxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Logs/Test/F063AE42-B5A6-41C3848607/Session-XCTestWDUITests-_181552-bw8Dwx.log}Testing failed:
Command /bin/sh failed with exit code 127** TEST FAILED **The following build commands failed:
PhaseScriptExecution Run\ Script /Usersx'x'x'x'x'x'x'xLibrary/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.sh(1 failure)
/Users/xxxxxxxxx/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.sh: line 12: ideviceinstaller: command not found
Command /bin/sh failed with exit code 127
brew install ideviceinstaller
这个装下试试
尴尬 看到了。。。。
装完了可以run了
不过这个参数制定在哪 比如多少次 还有间隔
目前这块还缺少 后续会补充上的。比如总运行时间,或者总点击次数。每次点击固定间隔,以及每次点击随机间隔
1.总运行时间,总点击次数。action固定间隔,action随机间隔(暂时内编码,后续参数化)
Monkey.swift
let elapsedTime = n
//设定跑monkey n秒后退出let actionMax = n
//设定跑monkey n个action后退出
(elapsedtime 与actionmax 二选一)
let throttle = n * 1000
randomize_throttle=false,则每个action之间 sleep throttle( n个毫秒)
let randomize_throttle = false
// randomize_throttle=true,则每个action之间 sleep
ramdom(throttle) 个毫秒
"多少次 还有间隔 "
已更新 看看是否符合需求
“添加 time = 1000s 一项,它就会自动在1000秒时停止monkey”
已更新 看看是否符合需求
不知道为什么跟着步骤走 都是这个报错
"code signing is required .."
你那里XCTestWDUITests配置的签名有问题
XCTestWDUITests-&General-&Signing
与 XCTestWD 一样
大神!!拜谢!!在github上下载最新的就可以了是吧!
最近发现经常会有这个问题,自己实现的解决办法是设备断连再重启,想知道大神有没有在根本上解决问题的方式?
从log上看 是报的签名invalid。
iphone上的 ‘设置-&通用-&设备管理’ XCTestWDUITests 设置受信任了吧?
一般跑完一次后,再跑第二次或第三次会发生这样的错误。
请问xxx/XCTestWD-xxx/Logs/Test/Attentment路径下的crashlog是发生了闪退才会生成相应文件是吗?
app闪退后仍会重新跑知道完成1000s才停止吗?
嗯 app闪退之后,监控线程就检测到了,然后会自动拉活待测的app然后继续跑monkey。 除了退出还有跳转到其他app也会切回继续跑。
crashlog 会生成在Attentment目录里,让研发查查崩溃的堆栈看是否能定位闪退。
第二次,第三次会出这个错误?我有空了调试看看。
请问下,第一步执行iproxy 命令,一直显示 waiting for connecting,是不是苹果手机需要越狱?;用xcode运行XCTestWD在真机上跑起来了,不过控制台没有输出。还有devicename就是苹果手机的udid吗?
iproxy后显示waiting for connecting 是对的,说明8001端口已经开始做映射了。 iphone 不需要越狱
需用xcode运行 XCTestWDUITests ,而不是XCTestWD,运行成功控制台会显示 server已启动并监控8001
devicename 不是udid 在xcode设备info里可以看到 是个string
感谢大佬的细心指点,我大概理解了,不过还是想请问下devicename
在xcode设备info里 是哪个string
是在 Xcode -& Window -&Devices
这是什么原因呢
第一步执行了,第二步成功了,第三步报这个错
或者在设备中,打开 通用→关于本机→名称
(该名称就是你的devicename)
iproxy 没执行成功 或 server没起来?
只是每次粗暴的全都停止,重新来一遍才能解决问题,不清楚具体原因。
你这个是不是上一个session还在占用着端口,下一次测试就开始了。 感觉像是这样子, 这两天我再改下版。跳过server这环节 到时候再试试。
private func fetchPort() -& in_port_t {
let arguments = ProcessInfo.processInfo.arguments
let index = arguments.index(of: "--port")
var startingPort:Int = Int(portNumber())
if index != nil {
if index! != NSNotFound || index! & arguments.count - 1{
startingPort = Int(arguments[index!+1])!
var (isValid, _) = checkTcpPortForListen(port: in_port_t(startingPort))
while isValid == false {
startingPort = startingPort + 1
(isValid, _) = checkTcpPortForListen(port: in_port_t(startingPort))
return in_port_t(startingPort)
查了下代码 原因基本明了。server启动时会检测端口是否被占用,如果占用则继续检测+1端口。直到有空闲端口
所以从log上看 你那里8001 应该是上个task还在占用中,本次监测完可能已经建立8002连接了。
增加跳过server 跳过发请求机制,运行xctestwduitest 直接启动待测app直接跑monkey (临时内编码,后续参数化)
XCTestWDMonkey.swift
public class XCTestWDMonkey {
func swiftmonkey() -& Int {
let bundleID = "com.pandatv.test.meizi"
//修改bundleid 为待测app 即可
var app : XCUIApplication!
var session : XCTestWDSession!
let path :String? = nil
app = XCUIApplication.init(privateWithPath: path, bundleID: bundleID)!
app!.launch()
XCTextWDRunner.swift
class XCTextWDRunner: XCTestCase {
var serverMode = true
// true 为原server 请求模式, false 为直接启动跑monkey模式
var server: XCTestWDServer?
var monkey: XCTestWDMonkey?
新增加的 XCTestWDMonkey.swift 项目中自行添加下
已更新 用新Mode 试下看看
“再问一下可否做到多台设备一起测试”
应该可以支持你说的需求了
使用新mode , xcodebuild时用不同的 -destination 'platform=iOS,name=(your device name)'
只需执行第二步和第三步?
只需要执行第二步就行了
大神报错情况如下,是不是少上传了某文件?
这个就在server目录下,工程里自己添加下就行。 我本地开发用的另一套工程怕全拷过来又出最开头那个问题了。
左侧选server。 File-&Add Files to "XCTestWD" -& 选XCTestWDMonkey.swift -&add
按照大神描述的设置完成后
项目运行无报错后
xcodebuild -project XCTestWD.xcodeproj \
-scheme XCTestWDUITests \
-destination 'platform=iOS,name=xxxx' \
XCTESTWD_PORT=8001 \
clean test
结果一直报错如下
Xcode的手动执行看能跑起来吗?
bundleID改成你自己app了吧?
能跑起来了,几秒种后报错
报的错误是什么?
XCTestWDMonkey我内编码的bundleID是我测试用的,这个你那修改的对吧?
终端运行报这样的错,和上面截图一样的
都是能看到成功启动了app,短暂的跑了几秒后就失败报错
你那里把 异常断点打开,再跑次看看崩到哪句里了
开启方法在120楼。exception 勾选上
我本地也调式看看。。
这边为什么乘两次1000??
前面的 “0”
是默认0 秒吗
支持的是微秒,所以 秒*
0表示不生效
我这里调试没出问题 -_-。 你把那个xxx.log发出来看看。
那边elapsedTime时间到了后
终端输出的log 也是
Testing failed:
Run test suite XCTextWDRunner encountered an error (Early unexpected exit, operation never finished bootstrapping - no restart will be attempted)
Failing tests:
-[XCTextWDRunner testRunner()]
** TEST FAILED **
这样的吗??
正常结束 什么样子的?
你那里是用新mode 然后设的 elapsedtime = 0了?
超时时 我直接exit了 所以xctest会认为test failed 。是正常的。后续看看怎么改下 正常结束下
serverMode 设为了 false
elapsedtime = n * 1000 * 1000
(n分别设置过10000 或 30 等等 )
按这个增加下崩溃断点。
跑下看具体崩溃到哪里了。
发现elapsedtime 设置稍微大一些就会这样,比如10000s就会发生以上错误
THX 是个bug。
U32int 越界了
设置比如100s的时候是可以正常运行的,10000s则报错,可以解决吗
已修改。更新下吧
嗯,谢谢了
221Floor has been deleted
222Floor has been deleted
223Floor has been deleted
elapsedtime =10000 就行,不用*了
225Floor has been deleted
帮来个215楼那个带具体定位。
这个截图没法定位错误。
这次没有绿色的崩溃点。。
有红色错误如206楼
设10000s时,那边可以坚持运行多久?
这边可以正常运行,但没几秒就停止了
我这能一直跑着的。 要不你随机加一些断点?
尝试了下,有几次是运行到这里就报错
usleep 你这是老代码了。又新更新了,解决了elapsedtime &10000 越界的问题。 你update新的再试试看?
DispatchQueue.global().async {
if self.elapsedTime != 0{ -
usleep(useconds_t(self.elapsedTime)) +
Thread.sleep(forTimeInterval: TimeInterval(self.elapsedTime))
232Floor has been deleted
不应该呢,我12点多重新拉取了一次的,后来就是觉得是不是没更新好 在快两点的时候又重新拉取得呢
最后一次拉取的时候 以下部分显示的是
" 2 hours ago "
拉取方法是 git clone xxxx
我再一次通过另一种download的方式新拷下来了代码。
发现大神拷出来的这段代码是应该是在174行,
我上方断点部分的是在203行
这两段代码类似
经确认发现
Monkey.swift文件中
174~177行 代码为大神新修改的代码
203~207行 代码仍为老代码
我将第二部分照着上方做了修改,目前已经打破无法跑过8秒的问题,已经跑了一段时间了!! 拜谢大神耐心回复
重新拉下 应该就行
中提及了此贴
,求教大神,执行xcodebuild -project XCTestWD.xcodeproj -scheme XCTestWDUITests -destination 'platform=iOS,name=lemon' XCTESTWD_PORT=8001 clean test 出现如下错误,求教如何解决,新手伸手党,惭愧~~
谢谢大神回复,这个设置我已经按照 的扫盲帖子修改过了,如下图:还是不行,跟上面同样的错误,疑惑
不是xctestwd 而是XCTestWDUITests 你的截图是xctestwd
谢谢大神的细心回复,看了你的回复和的帖子我有点不解,在步骤中描述说修改的是XCTestWD 的build settings,见下图,所以又蒙圈了~~
我自己实际操作了两种配置方案,都会报错,由于是小白级的伸手党,所以感觉无从下手,还请大神帮忙看下如何处理,万分感谢。
哦。sorry 我240楼 回答错了。。
xctestwd中的去掉,xctestwduitest需要保留
"xctestwd中没有用到oc,swift混编,header search path,objecktive-c bridging header 配置可去掉再试试。xctestwduitest中用了混编才需要 xctestwduitest-bridging-header.h"
第二个图里 报错 是因为去掉了 所以找不到相关的引用
谢谢回复,依旧还是出现之前我截图的那个错误, 我自己先搜搜看有没有解决方案,其他人有遇到或者知道解决方案的,帮忙回复下,万分感谢~
你那里xcode是多少版本?
果不其然。 9.0 太超前了。你看下你那的swift版本用的是多少?
需修改为swift3
我看了下,我选的是3.2,我再搜搜看,实在不行我就重新下个8.3的xcode再试试看 ,谢谢了
建议还是先换8.3吧。 9.0beta 或许有其他坑
中提及了此贴
我装了个8.3的,xctestwd运行成功了,但执行最后一个命令时,xctestwd自动打开后闪一下就关闭了,然后就出现下图的错误,monkey没有跑起来,辛苦帮忙再看下,感恩~?。另外我想问下,我时跑你的demo的,熊猫直播我真机上需要安装吗?
你上面图里输入的curl 需要先装熊猫tv才能调启它跑monkey的。
或者curl里bundleID改成你自己要测试的app
嗯 谢谢楼主,熊猫直播和熊猫主播版我都安装了,运行还是没跑起来 ,错误跟上面#251一样,我用我们自己要测的app,也是同样的错误失败提示,xctestwd一闪就关闭了。
我把XCTestWDMonkey.swift.中 的bundleID修改成要测试的app bundleID,也是老样子,
XCTestWDMonkey是新mode用的。如果用curl 就不用改XCTestWDMonkey
你那里iphone上设备-通用-设备管理-开发者 信任了吗
是这个信任吗?下图的这个信任我是确认了的。还是说要在设置-&通用-&描述文件与设备管理 里去信任什么证书之类的东西?
对应xctestwduitest的开发者账号需要 信任。
这样 你按#214 楼方法 把崩溃断点加上。跑次看看崩在哪里了
hi 楼主,断点显示没有错误,如下图所示:
另外我在xtestwd页面加了个button看了下,运行后,进到这个xcrtestwd主页面之后就停留在这个页面了,然后就没有调起熊猫tv
Xcode显示:
xtestwd 不用管的。就是个空壳
你看下 monkey.swift里
public class Monkey {
let elapsedTime = 0
let actionMax = 0
let throttle = 0 * 1000
// ?ms *1000
let randomize_throttle = false
这几个值设的多少?
class XCTextWDRunner: XCTestCase {
var serverMode = true
var server: XCTestWDServer?
xctestwd一闪就关闭了 是对的。
另外你那里 熊猫tv app启动就闪退了? 还是一点也没起来?
还是起来跑了一会再闪退的?
谢谢回复,我是直接从你github上clone下来的,所以没改动
那这样吧。在XCTestWDMonkeyController里 随机加些断点,单步调试跑下 看看?
internal static func swiftmonkey(request: Swifter.HttpRequest) -& Swifter.HttpResponse {
var app : XCUIApplication!
var session : XCTestWDSession!
let desiredCapabilities = request.jsonBody["desiredCapabilities"].dictionary
let path = desiredCapabilities?["app"]?.string ?? nil
let bundleID = desiredCapabilities?["bundleId"]?.string ?? nil
if bundleID == nil {
app = XCTestWDSession.activeApplication()
app = XCUIApplication.init(privateWithPath: path, bundleID: bundleID)!
app!.launchArguments = desiredCapabilities?["arguments"]?.arrayObject as! [String]? ?? [String]()
app!.launchEnvironment = desiredCapabilities?["environment"]?.dictionaryObject as! [String : String]? ?? [String:String]();
app!.launch()
if app != nil {
session = XCTestWDSession.sessionWithApplication(app!)
XCTestWDSessionManager.singleton.mountSession(session)
try? session.resolve()
if app?.processID == 0 {
return HttpResponse.internalServerError
NSLog("XCTestWDSetup-&start fastmonkey&-XCTestWDSetup")
_ = app.descendants(matching: .any).element(boundBy: 0).frame
let monkey = Monkey(frame: app.frame)
monkey.addDefaultXCTestPrivateActions()
monkey.addXCTestTapAlertAction(interval: 100, application: app)
monkey.addXCTestCheckCurrentApp(interval: 10, application: app)
//monkey.addXCTestAppLogin(interval: 50, application: app)
monkey.monkeyAround()
xetestwd闪先后,熊猫tv app没起来
-_- 你的iphone手机不会是 ios11吧?
不是,我试了两台:iPhone6s
iPhone6 10.3.2
你用的是多少的,我换个一样的看下
嗯。我这是10.3 之前10.0也试了。应该10,9 问题都不大。
我在 private func registerRouters() 打了个断点,貌似这个方法都没调起来,XCTestWDMonkeyController也没进去,心塞~
貌似是XCTestWD
系统限制了没起来??
还是回到原点 看看开发者账号那块是不是有什么问题?
我的开发者账号配置,楼主辛苦~感谢不厌其烦的回复,iOS伸手党小白?
269Floor has been deleted
hi 楼主 跟研发确认了,我用的公司的测试设备,你说的那些都是添加了的,但是还是依旧。。。。。
实在不行 你换个个人开发账号试试。占2个bundleID 免费版的就行。
hi 楼主,又来麻烦你了,我在XCTestWDMonkeyController里打了断点,发现到下图所示的位置后,继续执行就自动跳出去了,然后就一直不再往下执行了。
这里只是注册一些路由的回调,你那控制台log里有 XCTestWDSetup-&
如果有表示server 启动成功了
嗯,谢谢楼主回复,有看到,启动xctestwd后,就一直停在这个位置了,然后就没有然后了 ,我自己慢慢调调看吧,谢谢楼主,辛苦
14:05:18.752445 XCTRunner[5] Running tests...
14:05:20.780470 XCTRunner[5] Continuing to run tests in the background with task ID 1
Test Suite 'All tests' started at
14:05:21.378
Test Suite 'XCTestWDUITests.xctest' started at
14:05:21.379
Test Suite 'XCTextWDRunner' started at
14:05:21.380
Test Case '-[XCTestWDUITests.XCTextWDRunner testRunner]' started.
Start Test at
14:05:21.381
14:05:21.412191 XCTRunner[5] com.apple.test.XCTestWDUITests-Runner
14:05:21.412314 XCTRunner[5] XCTestWDSetup-&&-XCTestWDSetup
谢谢楼主提供的源码,我的问题解决了,现在可以跑起来了,发现问题竟然出现在设备名的命名上,我把我全英文字符的设备名改成xx's iphone,竟然跑起来了,但是没搞明白为什么会这样。
build 一直卡在这个地方
/bin/sh -c /Users/myName/Library/Developer/Xcode/DerivedData/XCTestWD-bskdnjihiujjaraablsvmjfcodst/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Script-7FA43F311F0CB5.sh
ecab65eca01ae1da33aee78296b6 ecab65eca01ae1da33aee78296b6
这个脚本是不是需要网络?之后莫名奇怪的好了。
swipe事件源码在哪个位置?表示看不懂swift代码
没有直接的swipe事件
drap事件、多次tap事件 也能达到swipe效果
内部调的都是 私有的api
sharedXCEventGenerator.pressAtPoint
好的,测试支持最大的时间是多久?
目前time可以设置 见
不设则一直monkey, 我测试一直跑到iphone卡死
大师没时间搞了
282Floor has been deleted
请问你用多台设备测试成功了吗?我这边用xcodebuild方式,在iproxy中添加了serialid之后,再通过curl会提示number of avaible devices == 2,是因为curl中的内容填写的不正确吗?
xcodebuild设置不同的deviceName也不行,iproxy
serialid xxx设置了之后,curl运行之后提示number of available devices == 2,不知道是哪里出错了,大神能不能说的更详细一些呢?
多台设备的话 别用server模式了。也就不用iproxy了。 直接用新mode。见191楼
新mode直接内编码直接启monkey,跳过了server及插入命令的过程。
跑多台设备的话,xcodebuild -project XCTestWD.xcodeproj
-scheme XCTestWDUITests
-destination 'platform=iOS,name=xxx'
XCTESTWD_PORT=8001
clean test,还是用这个命令吗?这个destination将name=xxx修改成另一台设备的名字即可对吧?这个port需要做修改吗?
嗯 还是的。 port 可以不用。带上也没事
只修改了name的字段之后,在跑第二台设备的时候,是一台5C设备,系统是10.3.3,先跑起来了,然后出现了这个异常:
Find the Application "com.xxx" 0x15e064c0
Snapshot accessibility hierarchy for com.xxx
15:23:11.0 XCTRunner[314:39254] XCTestWDSetup-&start fastmonkey&-XCTestWDSetup
Find the Any
Use cached accessibility hierarchy for com.xxx
Find: Descendants matching type Any
Find: Element at index 0
Find the Application "com.xxx" 0x15e064c0
Use cached accessibility hierarchy for com.xxx
XCTRunner(314,0x3b7b1e40) malloc: *** mach_vm_map(size=) failed (error code=3)
*** error: can't allocate region
*** set a breakpoint in malloc_error_break to debug
15:23:20.0 XCTRunner[314:39254] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[NSXPCEncoder checkObject:]: This coder only encodes objects that adopt NSSecureCoding (object is of class 'NSMallocBlock_').'
*** First throw call stack:
(0x1dfdbb3d 0x1dx1dfdba85 0x1e836ecd 0x1e836c2f 0x2cad7d 0x1ex1ex1ex1ex1eaeaex1dfdef63 0x1df07dc8 0x2da867 0x240dd8c 0xxxxxx1d6bd6b8d77 0x1d6ad6add05 0x1df97d69 0x1df95e19 0x1dee91af 0x1dee8fd1 0x1e83daf5 0x1e88adb9 0x24040ac 0xxx1dfedf042b9 0x2d06bd 0xx2d12b 0x2cffeb 0x2d0a39 0x2cdc23 0x2cd74b 0x2cd9bf 0x2cdc23 0x2cd74b 0x2cd9bf 0x2cdc23 0x2cd74b 0x2cd9bf 0x3160cb 0x2dc279 0x315f63 0x2b962b 0x30c439 0x1df97f15 0x1dfdf95f47 0x1dee91af 0x1dee8fd1 0x1f693b41 0xxf6fc5 0x1d6d64eb)
这个错误是代表有些区域获取结构的时候出现了异常吗?
mach_vm_map(size=) failed (error code=3)
*** error: can't allocate region
内存ran out了?
每次都在固定的位置Terminatie吗?
XCTRunner(242,0x3b9c9e40) malloc: *** mach_vm_map(size=) failed (error code=3)
*** error: can't allocate region
*** set a breakpoint in malloc_error_break to debug
17:00:07.0 XCTRunner[242:6204] *** Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: '*** -[NSXPCEncoder checkObject:]: This coder only encodes objects that adopt NSSecureCoding (object is of class 'NSMallocBlock_').'
这个mach_vm_map括号里面的size值都是一样的,基本都是刚起来到了某一个页面加载页面的时候出现的
哦。单个机跑的时候到 同样这个页面能monkey吗?
每步执行截图如何保存,runner没有权限写相册。另外截图量太大,对手机硬盘是个考验,大神们有何看法
好像跟是不是单机没关系,而且后来再跑的时候,不知道是不是因为没有正常结束,会出现这个错误提示:
), NSLocalizedRecoverySuggestion=Too many instances of this service are already running., NSLocalizedDescription=Too many instances of this service are already running.}
17:51:19.038 xcodebuild[6] Error Domain=IDETestOperationsObserverErrorDomain Code=6 "Early unexpected exit, operation never finished bootstrapping - no restart will be attempted" UserInfo={NSLocalizedDescription=Early unexpected exit, operation never finished bootstrapping - no restart will be attempted}
Testing failed:
Test target XCTestWDUITests encountered an error (Early unexpected exit, operation never finished bootstrapping - no restart will be attempted)
** TEST FAILED **
你那个内存ran out 是因为多机并行跑出的?
还是解析某个页面时出的?
用另一台6P就没有出现这个问题,用5C的这个单机跑也出现过这个问题~
ok 这次明白了。 这台5c支持的有问题,你在github上提交个issue简单说下问题吧,我这先记录下。但是我没有5c 具体原因不是很确定
并且xctest里面不能发起网络请求
截图无非是用来查看crash前一些截图 及 log来分析崩溃场景。
所以无需大量保存截图,只需保留crash前十几张即可。
我在代码中增加了手动造了一个崩溃,具体如下:
在Delegate.m中添加: self.window.rootViewController = self.tabBarC
self.window.backgroundColor = [UIColor orangeColor];
[self.window makeKeyAndVisible];
[NSTimer scheduledTimerWithTimeInterval:5 target:self selector:(test) userInfo:nil repeats:NO];
NSMutableArray *array1 = [NSMutableArray array];
self.array = array1;
return YES;
并且添加函数: - (void)test{
[self.array addObject:@"1"]; }
然后运行之后出现错误:(一般是在app自己卡住出现了崩溃的情况下会出现下面这样的错误)
Snapshot accessibility hierarchy for com.xxx
15:22:03.469370 XCTRunner[404:27133] *** Terminating app due to uncaught exception '_XCTestCaseInterruptionException', reason: 'Interrupting test' *** First throw call stack: (0x184cb41c0 0xx184cb1db1f0 0x 0xxc 0xxxxc 0xx 0x 0xx 0xx183b48dd4 0x183b3d1c0 0x183b4e0c4 0x183b3d1c0 0x183b41d6c 0x184c61f2c 0x184c5fb18 0x184b8e048 0x1x 0x1x 0x 0x184cba160 0x184badc3c 0x1001dca30 0xx100217dac 0xx1001dcd80 0x 0x 0x 0x 0x 0x 0x 0x 0x 0x 0x1001e88dc 0xx 0x 0x184ccc5f7b0 0x184b8e048 0xx18abab09c474 0x183b705b8) libc++abi.dylib: terminating with uncaught exception of type _XCTestCaseInterruptionException
15:22:09.940061 XCTRunner[419:27958] Running tests...
15:22:10.819493 XCTRunner[419:27958] Continuing to run tests in the background with task ID 1
Restarting after unexpected exit or crash in XCTextWDRunner/testRunner(); summary will include totals from previous launches.
Test Suite 'Selected tests' started at
15:22:11.419
Test Suite 'XCTestWDUITests.xctest' started at
15:22:11.422
Test Suite 'XCTestWDUITests.xctest' failed at
15:22:11.423.
Executed 1 test, with 1 failure (0 unexpected) in 0.000 (0.001) seconds Test Suite 'Selected tests' failed at
15:22:11.426.
Executed 1 test, with 1 failure (0 unexpected) in 0.000 (0.007) seconds Failing tests:
-[XCTextWDRunner testRunner()]
** TEST FAILED **
dump生成了吗?
修改了新的mode,然后用xcodebuild -project XCTestWD.xcodeproj -scheme XCTestWDUITests -destination 'platform=iOS,name=a' -destination 'platform=iOS,name=b' clean test,只能run起来a设备,b设备还是没有run起来。
修改了下运行时间,发现是a运行结束后,b才开始运行。
但是一修改运行时间,就会报错。
同时执行2次 destination不同的 xcodebuild 。
尝试了,解决啦,谢谢大神!
dump生成了,但是并不是在attachments的路径下,我们接了友盟的sdk,直接crash信息传到了友盟的平台上~
你的这个能crash 的 app 能否发我吗? 我隔天调试看看确定下问题
二位,你们谈到的 5c 会报 too many instances of this service are already running 据了解是一个 32 位设备的坑,目测短期内是不会修复了。解决办法很简单粗暴 重启
多机运行ok了,多谢大神,直接跳过sever的模式和用sever的有区别么
本质上没有区别
哦 有5c这个问题背景出处吗?
之前碰到的时候 google 过一圈,大概有印象。当时出问题的机器也是 5c 和一台 32位的 iPad,出处翻了一下没看到,可以看一下这个: 不过下面有人说 6s 也碰到了,我这边是没有发现过。
我也遇到这个问题了,断线,重启都试过了但是还不行,之前跑的还行,今天就不行
可有报了什么错?
11:02:02.0 XCTRunner[351:31926] Running tests...
11:02:03.0 XCTRunner[351:32001] Connection peer refused channel request for "dtxproxy:XCTestDriverInterface:XCTestManager_IDEInterface"; channel canceled
Failed to run tests: The operation couldn’t be completed. (DTXProxyChannel error 1.)
这个错,试了很多办法,重启也不行,我两个手机都好好的,两个ipad就这个错误
确实没遇到过,查stackoverflow 说换端口就行...
兄台有遇到过这个吗?
换了四个端口还真可以了,有些端口不知为啥不行
没有碰到过,面对 Stack Overflow 编程告诉我们换个端口试试- -
hi,楼主,又来麻烦你了。我已经按照44楼配置了登录,但是这边,已经运行到addXCTestLoginAction这个方法,但是并没有像预期一样输入账号和密码。。请问是怎么回事呢?
如果是运行到 addXCTestLoginAction的话会立即插入登录事件序列的
你在public func addXCTestLoginAction(application:XCUIApplication)
这个函数里加些断点调试看看跑到哪了?
recv failed:Resource temporarily unavailable
recv failed:Operation not permitted
请教怎么解决
fastmonkey经常有crash呢
我也遇到,有时候跑十几个小时,有时候两小时就Crash。。这是我常崩的地方
Restarting after unexpected exit or crash in XCTextWDRunner/testRunner(); summary will include totals from previous launches.
Test Suite 'Selected tests' started at
09:30:01.476
Test Suite 'XCTestWDUITests.xctest' started at
09:30:01.481
Test Suite 'XCTestWDUITests.xctest' failed at
09:30:01.483.
Executed 1 test, with 2 failures (0 unexpected) in 0.000 (0.001) seconds
Test Suite 'Selected tests' failed at
09:30:01.486.
Executed 1 test, with 2 failures (0 unexpected) in 0.000 (0.010) seconds
Failing tests:
-[XCTextWDRunner testRunner()]
-[XCTextWDRunner testRunner()]
** TEST FAILED **
我的总是这样的,我有时候几百秒就会崩溃。。。
可有什么切换app的场景?
check这个看来得改一下 ,这里面存在一个悖论……
跑的时候尽量少切换app. 目前我研究的来看 xcode9可以大致避免此问题了。争取10.1前后完成迁移提新版
已知是有一个概率性的崩溃存在。问题根源在于私有api只能在主线程中跑,而本该是于monkey并行的退出检测也就是那个check app目前是于monkey主体串行抢占式执行。另外checkapp那个函数为避免拉长整个action执行时间 特意做的非常快 大概只消耗20-30ms.
此两个问题就会存在一种情况 检测时app还没退出完认为是在前台,但之后某些action时取app。就此时app退出了就取不到了于是崩溃 ,另外一种反之 目测你这个崩溃就是后者
目前调研情况看可将退出检测改为非私有api 也就是切换到xcode9
升级到 xcode9后 一直报这个错
/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/PrivateHeaders/XCUIApplication.h:37:1: error: type of property 'unsigned long long' in class extension does not match property type in primary class1 error generated.&unknown&:0: error: failed to emit precompiled header '/Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates.noindex/PrecompiledHeaders/XCTestWDUITests-Bridging-Header-swift_HD8S09YT7455-clang_3F4FDQP5SKX2L.pch' for bridging header '/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/XCTestWDUITests-Bridging-Header.h'
是暂时不支持xcode9下跑吗
xcode9 我还在升级ing,很多代码估计都得重写。 苹果一贯如此
你们那还是先用xcode8吧。等兼容后再发个for xcode9
不过再安装一个xcode8后(终端已转到xcodebuild8)跑monkey 报错
Tests -emit-module-path /Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Objects-normal/arm64/XCTestWDRunner~partial.swiftmodule -emit-dependencies-path /Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Objects-normal/arm64/XCTestWDRunner.d -emit-reference-dependencies-path /Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Objects-normal/arm64/XCTestWDRunner.swiftdeps -o /Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Build/Intermediates/XCTestWD.build/Debug-iphoneos/XCTestWDUITests.build/Objects-normal/arm64/XCTestWDRunner.o/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/XCTestWDRunner.swift:15:17: error: use of undeclared type 'XCTestWDMonkey'
var monkey: XCTestWDMonkey?
^~~~~~~~~~~~~~/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/XCTestWDRunner.swift:34:27: error: use of unresolved identifier 'XCTestWDMonkey'
self.monkey = XCTestWDMonkey()
^~~~~~~~~~~~~~/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/server/XCTestWDServer.swift:12:14: note: did you mean 'XCTestWDServer'?public class XCTestWDServer {
^/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/XCTestWDRunner.swift:12:7: note: did you mean 'XCTextWDRunner'?class XCTextWDRunner: XCTestCase {
^XCTest.XCTestToolKey:2:12: note: did you mean 'XCTestToolKey'?public let XCTestToolKey: String
^/Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/server/models/XCTestWDReponse.swift:13:16: note: did you mean 'XCTestWDResponse'?internal class XCTestWDResponse {
^CompileSwift normal arm64 /Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD/XCTestWDUITests/server/models/XCTestWDErrors.swift
cd /Users/jackyoung/Documents/Monkey/Fastmonkey/XCTestWD-master/XCTestWD 21:54:51.572 xcodebuild[3] Error Domain=IDETestOperationsObserverErrorDomain Code=4 "Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/jackyoung/Library/Developer/Xcode/DerivedData/XCTestWD-ecleedtsdbxztvfcvaqqgwnsgqxl/Logs/Test/5-4FC7-A363-733A/Session-XCTestWDUITests-_215442-aWwF1c.log" UserInfo={NSLocalizedDescription=Test operation was canceled. If you believe this error represents a bug, please attach the log file at /Users/jackyoung/Library/Develope}

我要回帖

更多关于 电脑开机3秒就重启循环 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信