Airtest+Poco多设备并发自动化游戏测试框架(遇到的问题)_[pocoservice

img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上软件测试知识点,真正体系化!

由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新

需要这份系统化的资料的朋友,可以戳这里获取

from airtest.core.android.adb import *
sys.path.append(r"E:\test\xxx")
using(“test_function”)
from lasthero_report import LastHeroReport

class Shop(unittest.TestCase):
# 类属性
video_num = 5

@classmethod
def setUpClass(cls) -> None:
    global poco,lhr
    poco = UnityPoco()
    lhr = LastHeroReport(__file__, os.path.basename(__file__))


def setUp(self) -> None:
    pass

def test_1_video_diamond_num(self):
    """
    看视频兑换钻石次数检查
    """
    if poco("xxx").exists():
        pass
    else:
        poco("xxx").click()
    Shop.video_num = int(poco("xxx").get_text())
    assert_equal(Shop.video_num,4,"今日看视频兑换次数为5")
    print(Shop.video_num)


def test_2_accelerate(self):
    """
    检查打开加速提示文字是否正常
    """
    try:
        poco("xxx").swipe([0, -4], duration=1)
        sleep(3)
        poco("xxx").click()
        sleep(1)
        assert_equal(poco("xxx").exists(),True,"正常显示加速提示文字")
        sleep(1)
        poco("xxx").click()
    except Exception as e:
        log(e)

def tearDown(self) -> None:
    pass

@classmethod
def tearDownClass(cls) -> None:
    lhr.creat_report()

if name == “main”:
unittest.main()



生成报告封装类:
class LastHeroReport:
def init(self,filepath,filename):
self.file_name_list = filename.split(“.”)
self.log_dir = os.path.dirname(os.getcwd()) + “/log/” + self.file_name_list[0]
self.atr = os.path.dirname(os.getcwd()) + “/airtest_report/”
if not os.path.exists(self.log_dir):
os.makedirs(self.log_dir)
auto_setup(logdir=self.log_dir)
self.filepath = filepath

def creat_report(self):
    simple_report(self.filepath, logpath=self.log_dir, logfile='log.txt', output=self.atr + self.file_name_list[0] +'_log.html')


main:

用例顺序并发

from multiprocessing import Pool,Manager
import unittest
from airtest.core.android.adb import *
from airtest.core.api import *
sys.path.append(r"E:\test\xxxx")

cash_path = “E:/test/xxxx”

def g1_run(tag, q):
t = q.get()
connect_device(“Android://127.0.0.1:5037/”+t)
a = []
suit = addsuit()
for s in suit:
a.append(s)
runner = unittest.TextTestRunner()
runner.run(a[tag])
q.put(t)

def addsuit():
discover = unittest.defaultTestLoader.discover(cash_path,pattern=“test*.py”,top_level_dir=None)
return discover

def getdevices():
devices = []
adb = ADB()
devices_liset = adb.devices()
for i in devices_liset:
devices.append(i[0])
print(devices)
return devices

if name == “main”:
q = Manager().Queue()
a = []
dev = []
dev = getdevices()
pool = Pool(len(dev))
for i in dev:
q.put(i)
suit = addsuit()
for i in suit:
a.append(i)
i = len(a)
for tag in range(i):
pool.apply_async(g1_run, (tag, q,))
pool.close()
pool.join()


问题汇总:


1.如何导入其他air文件方法



from airtest.core.api import using

using(“actionset.air”)

from actionset import sign_board,authorize,callten


2.在python中运行airtest脚本



os.system(‘airtest run C:/Users/Administrator/AppData/Local/Temp/AirtestIDE/scripts/main.air --device Android://127.0.0.1:5037/HKL48N6K --log log/’)


–device Android://127.0.0.1:5037/HKL48N6K 中的–device是标识,不能直接去掉,这个标识是安卓手机


3.在python中运行完脚本后,输出和airtest中一样的报告



os.system(‘airtest report C:/Users/Administrator/AppData/Local/Temp/AirtestIDE/scripts/main.air --log_root D:/pythonwork/venv/log --outfile D:/pythonwork/venv/log/log.html --lang zh’)


4.在airtest中直接调用adb



(1)获取应用列表
adb shell dumpsys package > package.txt
(2)在package.txt查找自己需要启动的包名,及main activity,如
com.androlua.compass/com.androlua.Main
(3)在airtest中连接adb并且调用app
dev = connect_device(“Android://127.0.0.1:5037/xxxxxx”)
dev.shell(“am start -n com.xxxx.xxxx/com.unity3d.xxxx.xxxx”)


5.在airtest内导入py文件 在airtest路径下新建一个文件夹或者新建py文件,直接from 文件夹.文件 import 方法即可


6.airtest在start\_app后再进行poco初始化



ConnectionResetError: [WinError 10054] 远程主机强迫关闭了一个现有的连接
所以必须启动后再进行初始化,如下:
start_app(‘com.xxxx.test’)
assert_exists(APP启动后的图片, “是否启动APP”)
poco = UnityPoco()


7.使用poco().click()出现了偏移时解决方法(只适用于控件框范围内) 官方说明:点击默认点在 anchorPoint 上,每个UI都会有一个 anchorPoint ,也就是检视器(Inspector)中UI包围盒的那个红点,大部分情况下 anchorPoint 都在UI包围盒的正中央。如果想指定其他的点击位置,可以传一个参数到 click 方法中,这个参数是一个用list或tuple表示的2维向量,其 [x, y] 值分别表示相对于包围盒左上角的偏移量,左上角为 [0, 0] ,右下角为 [1, 1]


![在这里插入图片描述](https://img-blog.csdnimg.cn/cbd3b30a002747bebd5ca863138a359f.jpeg)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/c1d1fea010794851bae10ec94056ff8f.jpeg)  
 8.poco判断界面是否存在或者控件是否存在该界面



第一种情况
assert poco(“控件name”).exists(),“天赋10级打开”
第二种情况
assert poco(“控件name”).get_text() == “金币购买”,“金币不足跳转兑换界面”


9.poco查找控件的时候,一开始用的是poco(“控件name”),此时如果界面上相同name的时候可以用poco(text=“控件text内容”)


10.由于有时候会出现项目覆盖,导致出现ConnectionResetError: [WinError 10054] 远程主机强迫关闭了一个现有的连接 覆盖后需要重新在maincamera中添加pocomanaget


11.使用poco语句的断言导致在报告中没有显是断言,暂时使用airtest封装的断言,后续有方法在更新上来



1.assert poco(“lg_talentInstructions”).exists(),“天赋11级打开”
2.assert_equal(poco(“lg_talentInstructions”).exists(), True, “天赋11级打开”)


12.转移airtest上得用例,让项目规范化


![在这里插入图片描述](https://img-blog.csdnimg.cn/0368cf532b8d42b3a99305a1a5866bdc.jpeg)  
 新建pycharm项目时,导入了用例后需要进行pip安装airtest以及pocoui包 如果当前测试用例中有airtest的找图的方法时,转移到pycharm中要把图片也移动过去


test\_case:存放测试用例


test\_funcion:写了一些公共得方法


test\_image:用例中需要用到得一些图片


13.迁移项目得时候进行调试,发现了一些问题,所以想在airtestide中进行调试会出现如下图的报错,但是看了一下却是没问题的,直接在pycharm运行也不会报错,后面请教了一些大佬,airtestide中编写的任务代码会隐式的封装成unittest类函数,所以unittest里嵌套了unittest导致报错


![在这里插入图片描述](https://img-blog.csdnimg.cn/b7e8e624cd08404fa0b9d457a0a73e8c.jpeg)  
 14.在调试的时候误以为自己本机是有使用venv环境,发现运行脚本的时候不是使用venv路径的下的adb,所以开始看是什么原因导致。



<airtest.core.android.adb> C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\airtest\core\android\static\adb\windows\adb.exe devices


一开始通过网上查找,可能是配置解析器没有弄好,所以一开始再弄解析器,当时遇到几个问题:


1.由于自己本地的pycharm进行了汉化,所以导致图1图2一开始就显示异常,图1汉化的时候直接显示报错的一些文字信息,无法判断是对新项目进行的设置,第二个是再配置好解析器(实际配置的是新项目)后进行运行,此处发现一直运行不了,继续查资料,说是运行配置没有选择python解析器,当时找到配置解析器时发现左侧文件一开始选中,然后选择其他文件后无法点击回去,并且右侧显示空白,所以删除了本地汉化后,重新打开运行配置的时候就正常显示,并且发现一开始设置的解析器也是针对新项目,所以此时也修改回来,后续如果有同事电脑上的环境有不同版本的python再进行venv的配置


![在这里插入图片描述](https://img-blog.csdnimg.cn/0157be923ade43ecb8debb03b57cf8df.jpeg)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/3eaa9586e50f4f108d264ca588471d49.jpeg)


![在这里插入图片描述](https://img-blog.csdnimg.cn/3fba51c015c7418999e96c79cc47f95b.jpeg)  
 ![在这里插入图片描述](https://img-blog.csdnimg.cn/f92257e494ac4d939b2d5a5a93edf34e.jpeg)  
 15.使用pycharm调用到adb的时候出现如下报错:



报错:adb server version (40) doesn’t match this client (41); killing…
需要替换的adb版本路径:C:\Users\Administrator\AppData\Local\Programs\Python\Python37\lib\site-packages\airtest\core\android\static\adb\windows\


这个错是由于电脑上有2个adb版本导致的,接着开始替换电脑上的adb版本,从环境变量中查看了一下配置了adb的环境变量都替换掉,之后再运行依旧还是有报错,后面发现airtest调用当前路径的adb,所以只要找到airtest第三方库的路径下的adb替换即可,因为没有使用venv环境,所以包还是下载到本地的python路径


16.目前先使用unittest框架,后续再了解下pytest框架,先做出简单的用例并发


17.进程池通信的小坑



#以下会导致多进程不会执行
q = Queue()
pool = Pool(2)
pool.apply_async(g1_run, (q,))

#进程池内通信需要使用Manager().Queue()
q = Manager().Queue()
pool = Pool(2)
pool.apply_async(g1_run, (q,))


18.版本发完后有空进行一下调试,增加每个脚本前启动APP和结束APP,接着在调试的过程发现并发突然不好使了,启动APP是同事写的,这里创建了一个Android对象,使用了check\_app检查手机上的app是否存在和启动app。后面经过排查,使用了airtest的start\_app却是可以正常并发运行,查看了源码发现在connect\_device的时候调用过init\_device,获取到了当前的设备,而我们在创建command = Android()的时候并没有指定设备,当设备为空的时候就去找默认的设备,所以在并发的时候都是针对同一个手机进行了检查和启动,而没有指定设备,所以添加个设备参数即可



错误的源码:
def startapps():
command = Android()
if not command.check_app(packgename):
print(“当前未安装App!!!正在安装所需的App”)
install(apkpath)
command.start_app(packgename)
sleep(5)
if pocoo(text=“xx申请以下权限”).wait_for_appearance(30):
pocoo(text=“允许”).click()
修改:
def startapps(dev):
command = Android(dev)


19.运行脚本比较久的时候,突然提示



[pocoservice.apk] stdout: b’INSTRUMENTATION_RESULT: shortMsg=Process crashed.\r\nINSTRUMENTATION_CODE: 0\r\n’


后面查询到相关信息,开启手机相关的权限参考:https://airtest.doc.io.netease.com/IDEdocs/device\_connection/2\_android\_faq/#\_6


![在这里插入图片描述](https://img-blog.csdnimg.cn/cf111eb4e20444298770fe803a5d98d0.jpeg)


我使用的是vivo手机,所以在设置了相关功能后依旧会提示,所以我将开发者模式等等的开启,接着把自己测试的apk权限全部开启,并且开启了自启动,后续调试就正常了,如果有报这个错误的同学,可以尝试下把所有的权限都开启



![img](https://img-blog.csdnimg.cn/img_convert/c534d9248f3dca0aae9e7308ab706d75.png)
![img](https://img-blog.csdnimg.cn/img_convert/c7cbb88e7d4f807c645ea5263adf731d.png)

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

开启了自启动,后续调试就正常了,如果有报这个错误的同学,可以尝试下把所有的权限都开启



[外链图片转存中...(img-9KDziU0m-1715720626012)]
[外链图片转存中...(img-2EGXiFwh-1715720626012)]

**网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。**

**[需要这份系统化的资料的朋友,可以戳这里获取](https://bbs.csdn.net/topics/618631832)**

**一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!**

  • 23
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Airtest, Poco, Python, Pytest, Allure是一些用于实现Android App自动化测试框架的工具。这些工具结合使用可以实现对应用元素的定位(使用AirtestPoco),测试用例的管理和执行(使用Pytest),以及生成测试报告(使用Pytest-HTML或Allure)。 Airtest是一个基于Python的UI自动化测试框架,它可以用于Android、iOS等平台的应用自动化测试。它提供了丰富的API来进行界面元素的定位和操作,以及对应用的各种操作进行模拟和验证。 PocoAirtest的一个扩展库,它提供了一套更简单易用的API来进行应用元素的定位和操作。Poco可以与Airtest结合使用,使得测试用例编写更加简单和高效。 Python是一种流行的编程语言,对于测试框架的编写和测试脚本的编写都非常适用。通过使用Python,可以方便地编写和管理测试用例,以及进行各种数据处理和操作。 Pytest是Python的一个测试框架,它提供了丰富的功能和插件来管理和执行测试用例。Pytest可以与AirtestPoco结合使用,以便更好地管理和执行自动化测试用例。 Allure是一个用于生成漂亮且可视化的测试报告的工具。它可以将测试结果以图表和图形的形式展示,能够清晰地展示测试用例的执行情况和结果。 综上所述,AirtestPoco、Python、Pytest和Allure都是在Android App自动化测试中常用的工具和框架。它们的结合使用可以帮助开发人员和测试人员更方便地进行自动化测试的编写、管理和执行,并生成美观的测试报告来展示测试结果。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [Python + Airtest + poco + pytest + pytest-html 实现Android App自动化测试框架](https://blog.csdn.net/weixin_38813807/article/details/129179944)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [airtest/poco+pytest+allure+jenkins框架来了](https://blog.csdn.net/George513/article/details/119034783)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值