令人头秃的:你的主机中的软件中止了一个已建立的连接
1. 前言
最近在答疑群中,经常看到同学们遇到 你的主机中的软件中止了一个已建立的连接
这样的报错,这个报错可能的原因还挺多的,本质上是,无法连接服务。
一般来说,我们在poco初始化,或者是poco初始化之后“第一个”控件操作的语句中,就容易出现这个问题。
下面我们详细看下可能导致这个问题的几个常见场景:
2. 游戏应用未接入pocoSDK
如果我们的测试应用并非Android/iOS原生应用,而是游戏应用,那我们在初始化该游戏应用的poco之前,就需要先给游戏应用接入游戏引擎对应的PocoSDK。
成功接入PocoSDK并且应用打包过程无报错之后,我们可以在设备上 安装并启动 该应用,之后使用最新版的AirtestIDE连接该设备,在poco辅助窗选择正确的poco模式,查看能否显示正常的UI树。这个过程可以用来判断我们的游戏包,当前是否已经成功接入了对应的PocoSDK。
未接入pocoSDK的游戏应用,我们在初始化其poco时,将出现下述报错:
ConnectionAbortedError: [WinError 10053] 你的主机中的软件中止了一个已建立的连接。
因为此时包内没有挂载poco服务,我们无法与游戏建立通讯。
3. Poco初始化顺序问题
还有一种常见的情况是,我明明已经在游戏包内接入了pocoSDK,并且在IDE也可以正常看到游戏的UI树了,但是跑脚本的时候,却没法正常初始化poco,或者跑到第一个poco语句时,就报错 你的主机中的软件中止了一个已建立的连接
,通常是因为一些初始化的顺序问题。
其实本质问题是,我们的pocoSDK是接入在游戏内的,所以只有当游戏正常启动,进入到主界面之后,poco服务才会开始起来(通常会把poco服务挂载到根节点,以保证游戏启动后,能尽快建立poco服务)。
所以我们会要求在启动游戏之后,才去查看它的UI树,或者初始化该游戏的poco。
但有时候在写脚本的时候,可能没有关注到这个问题,我们来看这样子的一个示例代码:
# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
auto_setup(__file__,devices=["android://127.0.0.1:5037/127.0.0.1:7555"])
from poco.drivers.unity3d import UnityPoco
poco = UnityPoco()
start_app("com.NetEase")
sleep(1.0)
poco("btn_start").click()
看起来没有很大的问题,连接设备、初始化了一个unity poco,启动游戏,点击游戏内的控件,如果这里是Android poco的话,确实没有问题。
但是,我们强调过,游戏的poco服务是在应用里面的,我们这里没有启动游戏,也就意味着还没有启动游戏内的poco服务,此时强行先初始化一个unity poco,结果就之能是收到1个 你的主机中的软件中止了一个已建立的连接
的报错了。
那我们把顺序调整下:
# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
auto_setup(__file__,devices=["android://127.0.0.1:5037/127.0.0.1:7555"])
start_app("com.NetEase")
sleep(1.0)
from poco.drivers.unity3d import UnityPoco
poco = UnityPoco()
poco("btn_start").click()
这下应该没问题了吧,连接设备、启动游戏应用、初始化游戏poco,最后才进行控件操作,一切看起来都那么完美!
但是,实际运行过程,居然还是有很大概率收到 你的主机中的软件中止了一个已建立的连接
的报错,真是令人头秃!!
其实这里还有一个非常细碎的小细节需要注意下,就是我们使用 start_app
启动游戏应用,大部分游戏,启动到进入主界面时,也就是完全启动游戏,是需要一定时间的,可能是5s,可能是10s,这个跟设备和具体的游戏应用,都有关系,而在游戏没有完全启动时,里面的poco服务也没办法跟着起来,这就导致还有很大的概率出现报错了。
所以我们尽量在 start_app
之后,增加尽可能长一点的 sleep ,以确保游戏完成启动,再来初始化我们的游戏poco,同理,poco初始化语句之后,也可以适当的添加一点sleep,来保证poco初始化成功,再来进行控件操作:
# -*- encoding=utf8 -*-
__author__ = "AirtestProject"
from airtest.core.api import *
auto_setup(__file__,devices=["android://127.0.0.1:5037/127.0.0.1:7555"])
start_app("com.NetEase")
sleep(6.0)
from poco.drivers.unity3d import UnityPoco
poco = UnityPoco()
sleep(3.0)
poco("btn_start").click()
记住正确的顺序:先连接设备(一般在 auto_setup
接口里面连接)--> 再打开应用(一般用 start_app
接口)--> 等应用开启完毕(这里添加足够的 sleep
),最后才初始化 poco 。
4. 初始化远程iOS设备的poco问题
目前,我们仅支持初始化本地连接的iOS设备的poco(查看本地连接iOS设备的UI树),不支持初始化远程连接的iOS的poco。
强行初始化远程iOS设备的poco时,也将无法成功连接上服务。
5. Windows游戏的poco初始化问题
以Windows上的unity游戏为例,当我们在该客户端游戏上成功接入pocoSDK之后,我们支持在该Windows游戏上使用poco。
但是它的初始化脚本,与Android设备的unity poco,又有一些不一样:
# Android设备上的unity poco初始化
from poco.drivers.unity3d import UnityPoco
poco = UnityPoco()
# Windows上的unity poco初始化
dev = connect_device('Windows:///?title_re=^your game title.*$')
addr = ('', 5001)
poco = UnityPoco(addr, device=dev)
如果我们在Windows的unity游戏上,使用Android的初始化方式,也会导致无法连接服务,从而产生 你的主机中的软件中止了一个已建立的连接
的报错。
6. 连线不稳定的问题
也有少部分情况是,数据线连线不稳定的问题,导致连接暂时断了一下。如果我们在跑脚本的时候,发现一些不固定位置的偶现断开连接的报错,可以考虑是数据线连线不稳定的问题,请及时更换稳定的数据线,再来进行脚本跑测。
7. 其它问题
除了上述问题以外,可能还有一些别的问题,我们这里没有讲到;同学们在遇到该问题时,优先排除以上几个问题,若仍无法解决,请整理详细的复现情况给到我们开发组排查:https://airtest.netease.com/issue_create 。
Airtest官网:https://airtest.netease.com/
Airtest教程官网:https://airtest.doc.io.netease.com/
搭建企业私有云服务:https://airlab.163.com/b2b
官方答疑 Q 群:117973773
呀,这么认真都看到这里啦,帮忙点个推荐支持一下呗,灰常感谢~