uiautomator运行中获取运行状态

需求描述:

在手机平板端拷贝文件过程中需要在python端做些事情,比如在平板拷贝学习资料的过程中python端发个表情包:

需求分析:

因此需要在开始拷贝的时候告知python开始,在拷贝结束的时候告知python结束,方能精准控制过程并进行某些操作

已知情报:

uiautomator只有在test用例执行完毕之后方才打印信息(那些比如log.i()、System.out.println()什么的根正苗红才不会显示呢~)如下图所示:

解决思路:

宏观可知uiautomator是可以打印数据到cmd终端的(cmd终端输出映射到python主进程的管道中,因此python中方能poll得到数据),因此肯定是有方法可以打印中间过程的,此为总纲。

具体如何操作?

step1:尝试log.i()方式和System.out.println();后发现uiautomator是不支持打印数据到终端的(仅在androidstudio的log console界面显示打印信息);

step2:考虑打印到终端、打印到log文件、打印到管道,等等,这些都是可以重定向的,因此,把uiautomator里导向log文件的索引重新导向终端,这也是一个解决思路(源码不熟,找到接口艰难~摔~);

step3:继续仔细观察上述打印信息可知,打印信息来自于instrument,因此搜索它是如何实现的为解决线索,从stackoverflow找到的接口为instrumentation.sendStatus(),就是上述的打印信息!

step4:后续,当然可以继续深挖uiautomator、instrument框架的原理以及设计理念!(这是7月份战略目标!7月底希望能交付总结心得报告。)

解决方案1:

拷贝大文件,在开始拷贝后,直接退出,相当于告诉python,我跑完了,场景开始了,请开始你的表演!此时由于文件很大,拷贝时间很长,因此可以保证在场景开始后,进行用例的测试,但无法获知场景何时结束,也就是说是个半开半闭集合。

优点:简单粗暴直接方便···

缺点:不可预知结束点。

解决方案2:

将uiautomator部分拆开,先写场景开始部分,场景一开始就立马结束,然后python获知后马上开进程运行场景结束监测部分,也可实现需求。但是实时性会打折扣,比如后面监测部分可能会导致场景开始好几秒后方才开始监测,不过这都是小问题,最重要的是代码量增多了,写起来很麻烦。

优点:你就说问题解决没有!!!昂?

缺点:实时性要求高的场合可能不太适合,代码量有点多。

解决方案3:

python开启一个线程专门用来监控log文件(log cat),通过设置一些关键字来识别,可以实现。但是,可能存在这样的风险:由于buffer有限,且log cat是存全局的信息的,所以时间一长,可能会有部分log信息丢失。

优点:实时性较高;功能齐全。

缺点:读取log文件有点麻烦啊~同时解析log文件涉及到底层的io操作,这样比读内存还是慢上至少一个数量级的~

解决方案4:

java端直接通过 instrumentation.sendStatus(0,bundle);把关键信息实时打印到cmd,从而被python获取到(实测实时性约为0.5s),从而省去读log文件的过程,编写用例将会比较简洁。

优点:实时性好,python源代码无需修改即可实现中间过程监控,减少代码量。

缺点:放在最后面明显是主角啊,显然剧透了啊~

java代码demo:

@Before

public voidsetUp(){

instrumentation= InstrumentationRegistry.getInstrumentation();

device= UiDevice.getInstance(instrumentation);

}

@Test

public synchronized  voidpingpong()throwsUiObjectNotFoundException,RemoteException,InterruptedException,IOException {

System.out.println("enter time"+ System.currentTimeMillis());

device.pressHome();

/*重定向的方式来实现,但是想一下觉得还是不行!为什么不行呢?因为我不会啊~~~~~*/

System.out.println("quit time"+ System.currentTimeMillis());

Bundle bundle =newBundle();

bundle.putString("MyResult","0"+System.currentTimeMillis());

instrumentation.sendStatus(0,bundle);

}

实际的效果:

实时性:

# coding=utf-8

importsubprocess

importtime

cmd ="adb shell am instrument -w -r  -e debug false -e class com.softwinner.uiautomator.scene.Scene#pingpong\ com.softwinner.uiautomator.scene.test/android.support.test.runner.AndroidJUnitRunner"

p = subprocess.Popen(cmd,stdout=subprocess.PIPE,stderr=subprocess.STDOUT)

whilep.poll() is None:

out =str(p.stdout.readline())

if"MyResult"inout:

printout,time.time()

#INSTRUMENTATION_STATUS: MyResult=01498564332025

#1498564332.52

#1498564332.52 - 1498564332.025 = 0.495s

总结:四种解决方法各有各的优势,反正就是解决问题的工具而已,选个称手的就好啦~

最后,强烈感谢小组成员的帮助及指点,上述如若出现任何螺旋劈叉,有问题请出门左转直接@小南@小媚@小俊@小乐~



最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,607评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,047评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,496评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,405评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,400评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,479评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,883评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,535评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,743评论 1 295
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,544评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,612评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,309评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,881评论 3 306
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,891评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,136评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,783评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,316评论 2 342

推荐阅读更多精彩内容