mangoautomation 1.0.59__py3-none-any.whl → 1.1.2__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of mangoautomation might be problematic. Click here for more details.
- mangoautomation/enums/_ui_enum.py +3 -1
- mangoautomation/exceptions/error_msg.py +2 -2
- mangoautomation/models/_ui_model.py +19 -16
- mangoautomation/uidrive/_async_element.py +84 -55
- mangoautomation/uidrive/_sync_element.py +86 -57
- mangoautomation/uidrive/web/async_web/__init__.py +1 -1
- {mangoautomation-1.0.59.dist-info → mangoautomation-1.1.2.dist-info}/METADATA +1 -1
- {mangoautomation-1.0.59.dist-info → mangoautomation-1.1.2.dist-info}/RECORD +12 -13
- tests/get_ope.py +3 -7
- mangoautomation/exceptions/_error_msg.py +0 -68
- {mangoautomation-1.0.59.dist-info → mangoautomation-1.1.2.dist-info}/LICENSE +0 -0
- {mangoautomation-1.0.59.dist-info → mangoautomation-1.1.2.dist-info}/WHEEL +0 -0
- {mangoautomation-1.0.59.dist-info → mangoautomation-1.1.2.dist-info}/top_level.txt +0 -0
|
@@ -73,10 +73,12 @@ class ElementOperationEnum(BaseEnum):
|
|
|
73
73
|
ASS = 1
|
|
74
74
|
SQL = 2
|
|
75
75
|
CUSTOM = 3
|
|
76
|
+
CONDITION = 4
|
|
77
|
+
PYTHON_CODE = 5
|
|
76
78
|
|
|
77
79
|
@classmethod
|
|
78
80
|
def obj(cls):
|
|
79
|
-
return {0: "
|
|
81
|
+
return {0: "元素操作", 1: "断言操作", 2: "SQL变量", 3: "自定义变量", 4: "条件判断", 5: "python代码"}
|
|
80
82
|
|
|
81
83
|
|
|
82
84
|
class DeviceEnum(BaseEnum):
|
|
@@ -38,8 +38,8 @@ ERROR_MSG_0029 = (4029, '页面无元素【{}】,表达式:{}')
|
|
|
38
38
|
ERROR_MSG_0030 = (4030, '断言时没有找到元素')
|
|
39
39
|
ERROR_MSG_0031 = (4031, '元素未找到准备进行断言获取元素文本类容异常')
|
|
40
40
|
ERROR_MSG_0032 = (4032, '元素【{}】的元素表达式定位有多个,或其他元素异常,请检查元素是否可用')
|
|
41
|
-
ERROR_MSG_0036 = (4036, '
|
|
42
|
-
ERROR_MSG_0038 = (4038, '
|
|
41
|
+
ERROR_MSG_0036 = (4036, 'sql参数在数据库中查询不到结果,sql:{}')
|
|
42
|
+
ERROR_MSG_0038 = (4038, 'sql参数的sql_key不是列表')
|
|
43
43
|
ERROR_MSG_0040 = (
|
|
44
44
|
340, '设备启动超时!请检查设备是否开启了:文件传输模式、开发者模式、usb调试,开启后请重新连接电脑,设备号:{}')
|
|
45
45
|
ERROR_MSG_0041 = (4041, '查找页面元素【{}】时直接失败,报错信息:{}')
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
|
|
7
7
|
from pydantic import BaseModel
|
|
8
8
|
|
|
9
|
+
from mangoautomation.enums import ElementOperationEnum
|
|
9
10
|
from mangotools.models import MysqlConingModel, MethodModel
|
|
10
11
|
|
|
11
12
|
|
|
@@ -18,24 +19,24 @@ class EnvironmentConfigModel(BaseModel):
|
|
|
18
19
|
|
|
19
20
|
|
|
20
21
|
class ElementListModel(BaseModel):
|
|
21
|
-
exp: int
|
|
22
|
-
loc: str
|
|
22
|
+
exp: int
|
|
23
|
+
loc: str
|
|
24
|
+
sub: int | None = None
|
|
25
|
+
is_iframe: int | None
|
|
23
26
|
|
|
24
27
|
|
|
25
28
|
class ElementModel(BaseModel):
|
|
26
29
|
id: int
|
|
27
|
-
type:
|
|
30
|
+
type: ElementOperationEnum
|
|
28
31
|
name: str | None
|
|
29
32
|
elements: list[ElementListModel] = []
|
|
30
33
|
sleep: int | None
|
|
31
|
-
sub: int | None
|
|
32
|
-
is_iframe: int | None
|
|
33
34
|
ope_key: str | None
|
|
34
|
-
ope_value: list[MethodModel] | None
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
35
|
+
ope_value: list[MethodModel] | None = None
|
|
36
|
+
sql_execute: list[dict] | None = None
|
|
37
|
+
custom: list[dict] | None = None
|
|
38
|
+
condition_value: dict | None = None
|
|
39
|
+
func: str | None = None
|
|
39
40
|
|
|
40
41
|
|
|
41
42
|
class ElementListResultModel(BaseModel):
|
|
@@ -43,25 +44,27 @@ class ElementListResultModel(BaseModel):
|
|
|
43
44
|
exp: int | None = None
|
|
44
45
|
ele_quantity: int = 0
|
|
45
46
|
element_text: str | None = None
|
|
47
|
+
sub: int | None = None
|
|
48
|
+
is_iframe: int | None
|
|
46
49
|
|
|
47
50
|
|
|
48
51
|
class ElementResultModel(BaseModel):
|
|
49
52
|
id: int
|
|
50
53
|
name: str | None = None
|
|
51
54
|
sleep: int | None = None
|
|
52
|
-
sub: int | None = None
|
|
53
55
|
|
|
54
56
|
type: int
|
|
55
57
|
ope_key: str | None = None
|
|
56
|
-
ope_value:
|
|
58
|
+
ope_value: list[MethodModel] | None = None
|
|
59
|
+
sql_execute: list[dict] | None = None
|
|
60
|
+
custom: list[dict] | None = None
|
|
61
|
+
condition_value: dict | None = None
|
|
57
62
|
ass_msg: str | None = None
|
|
58
|
-
sql: str | None = None
|
|
59
|
-
key_list: str | None = None
|
|
60
|
-
key: str | None = None
|
|
61
|
-
value: str | None = None
|
|
62
63
|
|
|
63
64
|
elements: list[ElementListResultModel] = []
|
|
64
65
|
status: int = 0
|
|
65
66
|
error_message: str | None = None
|
|
66
67
|
picture_path: str | None = None
|
|
67
68
|
picture_name: str | None = None
|
|
69
|
+
|
|
70
|
+
next_node_id: int | None = None
|
|
@@ -28,8 +28,9 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
28
28
|
super().__init__(base_data)
|
|
29
29
|
self.drive_type = drive_type
|
|
30
30
|
self.element_model: Optional[ElementModel | None] = None
|
|
31
|
-
self.element_data: dict | None = None
|
|
32
31
|
self.element_result_model: Optional[ElementResultModel | None] = None
|
|
32
|
+
self.element_list_model: Optional[list[ElementModel] | None] = None
|
|
33
|
+
self.test_data = self.base_data.test_data
|
|
33
34
|
|
|
34
35
|
async def open_device(self, is_open: bool = False):
|
|
35
36
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
@@ -42,21 +43,20 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
42
43
|
self.base_data.log.debug(f'不存在这个类型,如果是非管理员看到这种提示,请联系管理员')
|
|
43
44
|
raise Exception('不存在的设备类型')
|
|
44
45
|
|
|
45
|
-
async def element_main(self,
|
|
46
|
+
async def element_main(self,
|
|
47
|
+
element_model: ElementModel,
|
|
48
|
+
element_list_model: list[ElementModel] | None = None) -> ElementResultModel:
|
|
46
49
|
self.element_model = element_model
|
|
47
|
-
self.
|
|
50
|
+
self.element_list_model = element_list_model
|
|
48
51
|
self.element_result_model = ElementResultModel(
|
|
49
52
|
id=self.element_model.id,
|
|
50
53
|
name=self.element_model.name,
|
|
51
|
-
sub=self.element_model.sub,
|
|
52
54
|
sleep=self.element_model.sleep,
|
|
53
55
|
|
|
54
|
-
type=self.element_model.type,
|
|
56
|
+
type=self.element_model.type.value,
|
|
55
57
|
ope_key=self.element_model.ope_key,
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
key=self.element_model.key,
|
|
59
|
-
value=self.element_model.value,
|
|
58
|
+
sql_execute=self.element_model.sql_execute,
|
|
59
|
+
custom=self.element_model.custom,
|
|
60
60
|
|
|
61
61
|
status=StatusEnum.FAIL.value,
|
|
62
62
|
)
|
|
@@ -91,14 +91,18 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
91
91
|
@async_retry()
|
|
92
92
|
async def __main(self):
|
|
93
93
|
self.base_data.verify_equipment(self.drive_type)
|
|
94
|
-
if self.element_model.type == ElementOperationEnum.OPE
|
|
94
|
+
if self.element_model.type == ElementOperationEnum.OPE:
|
|
95
95
|
await self.__ope()
|
|
96
|
-
elif self.element_model.type == ElementOperationEnum.ASS
|
|
96
|
+
elif self.element_model.type == ElementOperationEnum.ASS:
|
|
97
97
|
await self.__ass()
|
|
98
|
-
elif self.element_model.type == ElementOperationEnum.SQL
|
|
98
|
+
elif self.element_model.type == ElementOperationEnum.SQL:
|
|
99
99
|
await self.__sql()
|
|
100
|
-
elif self.element_model.type == ElementOperationEnum.CUSTOM
|
|
100
|
+
elif self.element_model.type == ElementOperationEnum.CUSTOM:
|
|
101
101
|
await self.__custom()
|
|
102
|
+
elif self.element_model.type == ElementOperationEnum.CONDITION:
|
|
103
|
+
await self.__condition()
|
|
104
|
+
elif self.element_model.type == ElementOperationEnum.PYTHON_CODE:
|
|
105
|
+
await self.__python_code()
|
|
102
106
|
else:
|
|
103
107
|
raise MangoAutomationError(*ERROR_MSG_0015)
|
|
104
108
|
|
|
@@ -106,11 +110,9 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
106
110
|
try:
|
|
107
111
|
for i in self.element_model.elements:
|
|
108
112
|
i.loc = self.base_data.test_data.replace(i.loc)
|
|
109
|
-
self.
|
|
113
|
+
i.sub = self.base_data.test_data.replace(i.sub)
|
|
110
114
|
self.element_model.sleep = self.base_data.test_data.replace(self.element_model.sleep)
|
|
111
115
|
self.element_result_model.sleep = self.element_model.sleep
|
|
112
|
-
self.element_model.sub = self.base_data.test_data.replace(self.element_model.sub)
|
|
113
|
-
self.element_result_model.sub = self.element_model.sub
|
|
114
116
|
|
|
115
117
|
except MangoAutomationError as error:
|
|
116
118
|
self.base_data.log.error(f'操作元素解析数据失败,类型:{type(error)}, 详情:{error}')
|
|
@@ -144,62 +146,76 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
144
146
|
)
|
|
145
147
|
else:
|
|
146
148
|
pass
|
|
147
|
-
self.element_result_model.ope_value =
|
|
149
|
+
self.element_result_model.ope_value = self.element_model.ope_value
|
|
150
|
+
for i in self.element_result_model.ope_value:
|
|
151
|
+
if not isinstance(i.v, str):
|
|
152
|
+
i.v = str(i.v)
|
|
148
153
|
|
|
149
|
-
async def __ass(self):
|
|
154
|
+
async def __ass(self, _ope_value: dict | None = None):
|
|
150
155
|
if self.element_model.ope_value is None:
|
|
151
156
|
raise MangoAutomationError(*ERROR_MSG_0054)
|
|
152
157
|
await self.__ope_value(True)
|
|
158
|
+
ope_value = {i.f: i.v for i in self.element_model.ope_value}
|
|
159
|
+
if _ope_value is not None:
|
|
160
|
+
ope_value.update(_ope_value)
|
|
153
161
|
try:
|
|
154
162
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
155
163
|
self.element_result_model.ass_msg = await self.web_assertion_element(
|
|
156
164
|
self.element_model.name,
|
|
157
165
|
self.element_model.ope_key,
|
|
158
|
-
|
|
166
|
+
ope_value
|
|
159
167
|
)
|
|
160
168
|
elif self.drive_type == DriveTypeEnum.ANDROID.value:
|
|
161
169
|
self.element_result_model.ass_msg = self.a_assertion_element(
|
|
162
170
|
self.element_model.name,
|
|
163
171
|
self.element_model.ope_key,
|
|
164
|
-
|
|
172
|
+
ope_value
|
|
165
173
|
)
|
|
166
174
|
else:
|
|
167
175
|
pass
|
|
168
176
|
except MangoAutomationError as error:
|
|
169
177
|
self.element_result_model.ass_msg = error.msg
|
|
170
178
|
raise error
|
|
171
|
-
self.element_result_model.ope_value =
|
|
179
|
+
self.element_result_model.ope_value = self.element_model.ope_value
|
|
180
|
+
for i in self.element_result_model.ope_value:
|
|
181
|
+
if not isinstance(i.v, str):
|
|
182
|
+
i.v = str(i.v)
|
|
172
183
|
|
|
173
184
|
async def __sql(self):
|
|
174
|
-
|
|
175
|
-
sql = self.base_data.test_data.replace(self.element_model.sql)
|
|
176
|
-
key_list = self.element_model.key_list
|
|
177
|
-
else:
|
|
178
|
-
sql = self.base_data.test_data.replace(self.element_data.get('sql'))
|
|
179
|
-
key_list = self.element_data.get('key_list')
|
|
180
|
-
if self.base_data.mysql_connect:
|
|
185
|
+
async def run(sql, key_list):
|
|
181
186
|
result_list: list[dict] = self.base_data.mysql_connect.condition_execute(sql)
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
self.base_data.test_data.set_cache(key, result.get(value))
|
|
187
|
-
except SyntaxError as error:
|
|
188
|
-
self.base_data.log.debug(
|
|
189
|
-
f'SQL执行失败-1,类型:{type(error)},失败详情:{error},失败明细:{traceback.format_exc()}')
|
|
190
|
-
raise MangoAutomationError(*ERROR_MSG_0038)
|
|
187
|
+
self.base_data.log.debug(f'sql参数->key:{sql},value:{result_list}')
|
|
188
|
+
if not isinstance(result_list, list) and not len(result_list) > 0:
|
|
189
|
+
raise MangoAutomationError(*ERROR_MSG_0036, value=(self.element_model.sql_execute,))
|
|
190
|
+
self.base_data.test_data.set_sql_cache(key_list, result_list[0])
|
|
191
191
|
|
|
192
|
-
|
|
193
|
-
|
|
192
|
+
if self.base_data.mysql_connect:
|
|
193
|
+
for i in self.element_model.sql_execute:
|
|
194
|
+
await run(i.get('sql'), i.get('key_list'))
|
|
194
195
|
|
|
195
196
|
async def __custom(self):
|
|
196
|
-
|
|
197
|
-
key
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
197
|
+
for i in self.element_model.custom:
|
|
198
|
+
self.base_data.test_data.set_cache(i.get('key'), self.base_data.test_data.replace(i.get('value')))
|
|
199
|
+
|
|
200
|
+
async def __condition(self):
|
|
201
|
+
error_list = []
|
|
202
|
+
for i in self.element_list_model:
|
|
203
|
+
try:
|
|
204
|
+
condition_value = self.base_data.test_data.replace(i.condition_value)
|
|
205
|
+
self.base_data.log.debug(f'执行条件判断数据:{self.element_model.id},{condition_value}')
|
|
206
|
+
await self.__ass(condition_value)
|
|
207
|
+
self.element_result_model.next_node_id = i.id
|
|
208
|
+
return
|
|
209
|
+
except Exception as error:
|
|
210
|
+
self.base_data.log.debug(f'节点判断中-错误:{error},明细:{traceback.print_exc()}')
|
|
211
|
+
error_list.append(error)
|
|
212
|
+
raise error_list[0]
|
|
213
|
+
|
|
214
|
+
async def __python_code(self):
|
|
215
|
+
self.base_data.log.debug(f'执行python函数:{self.element_model.func}')
|
|
216
|
+
global_namespace = {}
|
|
217
|
+
exec(self.element_model.func, global_namespace)
|
|
218
|
+
global_namespace['func'](self)
|
|
203
219
|
|
|
204
220
|
async def __ope_value(self, is_ass: bool = False):
|
|
205
221
|
try:
|
|
@@ -212,28 +228,41 @@ class AsyncElement(AsyncWebDevice, AndroidDriver):
|
|
|
212
228
|
'_type': self.element_model.type,
|
|
213
229
|
'exp': self.element_model.elements[random_element].exp,
|
|
214
230
|
'loc': self.element_model.elements[random_element].loc,
|
|
215
|
-
'sub': self.element_model.sub
|
|
231
|
+
'sub': self.element_model.elements[random_element].sub
|
|
216
232
|
}
|
|
217
233
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
218
234
|
loc, ele_quantity, element_text = await self.web_find_ele(
|
|
219
|
-
**find_params, is_iframe=self.element_model.is_iframe)
|
|
235
|
+
**find_params, is_iframe=self.element_model.elements[random_element].is_iframe)
|
|
220
236
|
elif self.drive_type == DriveTypeEnum.ANDROID.value:
|
|
221
237
|
loc, ele_quantity, element_text = self.a_find_ele(**find_params)
|
|
222
238
|
else:
|
|
223
239
|
loc, ele_quantity, element_text = None, 0, None
|
|
224
|
-
|
|
225
|
-
|
|
240
|
+
new_element = ElementListResultModel(
|
|
241
|
+
exp=self.element_model.elements[random_element].exp,
|
|
242
|
+
loc=self.element_model.elements[random_element].loc,
|
|
243
|
+
sub=self.element_model.elements[random_element].sub,
|
|
244
|
+
ele_quantity=ele_quantity,
|
|
245
|
+
element_text=element_text,
|
|
246
|
+
is_iframe=self.element_model.elements[random_element].is_iframe
|
|
247
|
+
)
|
|
248
|
+
|
|
249
|
+
element_exists = any(
|
|
250
|
+
existing.exp == new_element.exp and
|
|
251
|
+
existing.loc == new_element.loc and
|
|
252
|
+
existing.sub == new_element.sub and
|
|
253
|
+
existing.is_iframe == new_element.is_iframe
|
|
254
|
+
for existing in self.element_result_model.elements
|
|
255
|
+
)
|
|
256
|
+
|
|
257
|
+
if not element_exists:
|
|
258
|
+
self.element_result_model.elements.append(new_element)
|
|
226
259
|
if is_ass:
|
|
227
260
|
if callable(getattr(AsyncWebAssertion, self.element_model.ope_key, None)):
|
|
228
261
|
i.v = loc
|
|
229
262
|
elif callable(getattr(MangoAssertion(), self.element_model.ope_key, None)):
|
|
230
|
-
i.v =
|
|
263
|
+
i.v = element_text
|
|
231
264
|
else:
|
|
232
265
|
i.v = loc
|
|
233
|
-
elif self.element_data:
|
|
234
|
-
for f, v in self.element_data.items():
|
|
235
|
-
if f == i.f:
|
|
236
|
-
i.v = self.base_data.test_data.replace(v)
|
|
237
266
|
i.v = self.base_data.test_data.replace(i.v)
|
|
238
267
|
|
|
239
268
|
except AttributeError as error:
|
|
@@ -28,8 +28,9 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
28
28
|
super().__init__(base_data)
|
|
29
29
|
self.drive_type = drive_type
|
|
30
30
|
self.element_model: Optional[ElementModel | None] = None
|
|
31
|
-
self.element_data: dict | None = None
|
|
32
31
|
self.element_result_model: Optional[ElementResultModel | None] = None
|
|
32
|
+
self.element_list_model: Optional[list[ElementModel] | None] = None
|
|
33
|
+
self.test_data = self.base_data.test_data
|
|
33
34
|
|
|
34
35
|
def open_device(self, is_open: bool = False):
|
|
35
36
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
@@ -42,21 +43,20 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
42
43
|
self.base_data.log.error(f'不存在这个类型,如果是非管理员看到这种提示,请联系管理员')
|
|
43
44
|
raise Exception('不存在的设备类型')
|
|
44
45
|
|
|
45
|
-
def element_main(self,
|
|
46
|
+
def element_main(self,
|
|
47
|
+
element_model: ElementModel,
|
|
48
|
+
element_list_model: list[ElementModel] | None = None) -> ElementResultModel:
|
|
46
49
|
self.element_model = element_model
|
|
47
|
-
self.
|
|
50
|
+
self.element_list_model = element_list_model
|
|
48
51
|
self.element_result_model = ElementResultModel(
|
|
49
52
|
id=self.element_model.id,
|
|
50
53
|
name=self.element_model.name,
|
|
51
|
-
sub=self.element_model.sub,
|
|
52
54
|
sleep=self.element_model.sleep,
|
|
53
55
|
|
|
54
|
-
type=self.element_model.type,
|
|
56
|
+
type=self.element_model.type.value,
|
|
55
57
|
ope_key=self.element_model.ope_key,
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
key=self.element_model.key,
|
|
59
|
-
value=self.element_model.value,
|
|
58
|
+
sql_execute=self.element_model.sql_execute,
|
|
59
|
+
custom=self.element_model.custom,
|
|
60
60
|
|
|
61
61
|
status=StatusEnum.FAIL.value,
|
|
62
62
|
)
|
|
@@ -91,14 +91,18 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
91
91
|
@sync_retry()
|
|
92
92
|
def __main(self):
|
|
93
93
|
self.base_data.verify_equipment(self.drive_type)
|
|
94
|
-
if self.element_model.type == ElementOperationEnum.OPE
|
|
94
|
+
if self.element_model.type == ElementOperationEnum.OPE:
|
|
95
95
|
self.__ope()
|
|
96
|
-
elif self.element_model.type == ElementOperationEnum.ASS
|
|
96
|
+
elif self.element_model.type == ElementOperationEnum.ASS:
|
|
97
97
|
self.__ass()
|
|
98
|
-
elif self.element_model.type == ElementOperationEnum.SQL
|
|
98
|
+
elif self.element_model.type == ElementOperationEnum.SQL:
|
|
99
99
|
self.__sql()
|
|
100
|
-
elif self.element_model.type == ElementOperationEnum.CUSTOM
|
|
100
|
+
elif self.element_model.type == ElementOperationEnum.CUSTOM:
|
|
101
101
|
self.__custom()
|
|
102
|
+
elif self.element_model.type == ElementOperationEnum.CONDITION:
|
|
103
|
+
self.__condition()
|
|
104
|
+
elif self.element_model.type == ElementOperationEnum.PYTHON_CODE:
|
|
105
|
+
self.__python_code()
|
|
102
106
|
else:
|
|
103
107
|
raise MangoAutomationError(*ERROR_MSG_0015)
|
|
104
108
|
|
|
@@ -106,11 +110,9 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
106
110
|
try:
|
|
107
111
|
for i in self.element_model.elements:
|
|
108
112
|
i.loc = self.base_data.test_data.replace(i.loc)
|
|
109
|
-
self.
|
|
113
|
+
i.sub = self.base_data.test_data.replace(i.sub)
|
|
110
114
|
self.element_model.sleep = self.base_data.test_data.replace(self.element_model.sleep)
|
|
111
115
|
self.element_result_model.sleep = self.element_model.sleep
|
|
112
|
-
self.element_model.sub = self.base_data.test_data.replace(self.element_model.sub)
|
|
113
|
-
self.element_result_model.sub = self.element_model.sub
|
|
114
116
|
|
|
115
117
|
except MangoAutomationError as error:
|
|
116
118
|
self.base_data.log.error(f'操作元素解析数据失败,类型:{type(error)}, 详情:{error}')
|
|
@@ -144,62 +146,76 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
144
146
|
)
|
|
145
147
|
else:
|
|
146
148
|
pass
|
|
147
|
-
self.element_result_model.ope_value =
|
|
149
|
+
self.element_result_model.ope_value = self.element_model.ope_value
|
|
150
|
+
for i in self.element_result_model.ope_value:
|
|
151
|
+
if not isinstance(i.v, str):
|
|
152
|
+
i.v = str(i.v)
|
|
148
153
|
|
|
149
|
-
def __ass(self):
|
|
154
|
+
async def __ass(self, _ope_value: dict | None = None):
|
|
150
155
|
if self.element_model.ope_value is None:
|
|
151
156
|
raise MangoAutomationError(*ERROR_MSG_0054)
|
|
152
157
|
self.__ope_value(True)
|
|
158
|
+
ope_value = {i.f: i.v for i in self.element_model.ope_value}
|
|
159
|
+
if _ope_value is not None:
|
|
160
|
+
ope_value.update(_ope_value)
|
|
153
161
|
try:
|
|
154
162
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
155
163
|
self.element_result_model.ass_msg = self.web_assertion_element(
|
|
156
164
|
self.element_model.name,
|
|
157
165
|
self.element_model.ope_key,
|
|
158
|
-
|
|
166
|
+
ope_value
|
|
159
167
|
)
|
|
160
168
|
elif self.drive_type == DriveTypeEnum.ANDROID.value:
|
|
161
169
|
self.element_result_model.ass_msg = self.a_assertion_element(
|
|
162
170
|
self.element_model.name,
|
|
163
171
|
self.element_model.ope_key,
|
|
164
|
-
|
|
172
|
+
ope_value
|
|
165
173
|
)
|
|
166
174
|
else:
|
|
167
175
|
pass
|
|
168
176
|
except MangoAutomationError as error:
|
|
169
177
|
self.element_result_model.ass_msg = error.msg
|
|
170
178
|
raise error
|
|
171
|
-
self.element_result_model.ope_value =
|
|
179
|
+
self.element_result_model.ope_value = self.element_model.ope_value
|
|
180
|
+
for i in self.element_result_model.ope_value:
|
|
181
|
+
if not isinstance(i.v, str):
|
|
182
|
+
i.v = str(i.v)
|
|
172
183
|
|
|
173
184
|
def __sql(self):
|
|
174
|
-
|
|
175
|
-
sql = self.base_data.test_data.replace(self.element_model.sql)
|
|
176
|
-
key_list = self.element_model.key_list
|
|
177
|
-
else:
|
|
178
|
-
sql = self.base_data.test_data.replace(self.element_data.get('sql'))
|
|
179
|
-
key_list = self.element_data.get('key_list')
|
|
180
|
-
if self.base_data.mysql_connect:
|
|
185
|
+
def run(sql, key_list):
|
|
181
186
|
result_list: list[dict] = self.base_data.mysql_connect.condition_execute(sql)
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
self.base_data.test_data.set_cache(key, result.get(value))
|
|
187
|
-
except SyntaxError as error:
|
|
188
|
-
self.base_data.log.debug(
|
|
189
|
-
f'SQL执行失败-1,类型:{type(error)},失败详情:{error},失败明细:{traceback.format_exc()}')
|
|
190
|
-
raise MangoAutomationError(*ERROR_MSG_0038)
|
|
187
|
+
self.base_data.log.debug(f'sql参数->key:{sql},value:{result_list}')
|
|
188
|
+
if not isinstance(result_list, list) and not len(result_list) > 0:
|
|
189
|
+
raise MangoAutomationError(*ERROR_MSG_0036, value=(self.element_model.sql_execute,))
|
|
190
|
+
self.base_data.test_data.set_sql_cache(key_list, result_list[0])
|
|
191
191
|
|
|
192
|
-
|
|
193
|
-
|
|
192
|
+
if self.base_data.mysql_connect:
|
|
193
|
+
for i in self.element_model.sql_execute:
|
|
194
|
+
run(i.get('sql'), i.get('key_list'))
|
|
194
195
|
|
|
195
196
|
def __custom(self):
|
|
196
|
-
|
|
197
|
-
key
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
197
|
+
for i in self.element_model.custom:
|
|
198
|
+
self.base_data.test_data.set_cache(i.get('key'), self.base_data.test_data.replace(i.get('value')))
|
|
199
|
+
|
|
200
|
+
def __condition(self):
|
|
201
|
+
error_list = []
|
|
202
|
+
for i in self.element_list_model:
|
|
203
|
+
try:
|
|
204
|
+
condition_value = self.base_data.test_data.replace(i.condition_value)
|
|
205
|
+
self.base_data.log.debug(f'执行条件判断数据:{self.element_model.id},{condition_value}')
|
|
206
|
+
self.__ass(condition_value)
|
|
207
|
+
self.element_result_model.next_node_id = i.id
|
|
208
|
+
return
|
|
209
|
+
except Exception as error:
|
|
210
|
+
self.base_data.log.debug(f'节点判断中-错误:{error},明细:{traceback.print_exc()}')
|
|
211
|
+
error_list.append(error)
|
|
212
|
+
raise error_list[0]
|
|
213
|
+
|
|
214
|
+
def __python_code(self):
|
|
215
|
+
self.base_data.log.debug(f'执行python函数:{self.element_model.func}')
|
|
216
|
+
global_namespace = {}
|
|
217
|
+
exec(self.element_model.func, global_namespace)
|
|
218
|
+
global_namespace['func'](self)
|
|
203
219
|
|
|
204
220
|
def __ope_value(self, is_ass: bool = False):
|
|
205
221
|
try:
|
|
@@ -212,29 +228,42 @@ class SyncElement(SyncWebDevice, AndroidDriver):
|
|
|
212
228
|
'_type': self.element_model.type,
|
|
213
229
|
'exp': self.element_model.elements[random_element].exp,
|
|
214
230
|
'loc': self.element_model.elements[random_element].loc,
|
|
215
|
-
'sub': self.element_model.sub
|
|
231
|
+
'sub': self.element_model.elements[random_element].sub
|
|
216
232
|
}
|
|
217
233
|
if self.drive_type == DriveTypeEnum.WEB.value:
|
|
218
|
-
loc, ele_quantity, element_text = self.web_find_ele(
|
|
219
|
-
|
|
234
|
+
loc, ele_quantity, element_text = self.web_find_ele(
|
|
235
|
+
**find_params,is_iframe=self.element_model.is_iframe)
|
|
220
236
|
elif self.drive_type == DriveTypeEnum.ANDROID.value:
|
|
221
237
|
loc, ele_quantity, element_text = self.a_find_ele(**find_params)
|
|
222
238
|
else:
|
|
223
239
|
loc, ele_quantity, element_text = None, 0, None
|
|
224
|
-
|
|
225
|
-
|
|
240
|
+
new_element = ElementListResultModel(
|
|
241
|
+
exp=self.element_model.elements[random_element].exp,
|
|
242
|
+
loc=self.element_model.elements[random_element].loc,
|
|
243
|
+
sub=self.element_model.elements[random_element].sub,
|
|
244
|
+
ele_quantity=ele_quantity,
|
|
245
|
+
element_text=element_text,
|
|
246
|
+
is_iframe=self.element_model.elements[random_element].is_iframe
|
|
247
|
+
)
|
|
248
|
+
|
|
249
|
+
element_exists = any(
|
|
250
|
+
existing.exp == new_element.exp and
|
|
251
|
+
existing.loc == new_element.loc and
|
|
252
|
+
existing.sub == new_element.sub and
|
|
253
|
+
existing.is_iframe == new_element.is_iframe
|
|
254
|
+
for existing in self.element_result_model.elements
|
|
255
|
+
)
|
|
256
|
+
|
|
257
|
+
if not element_exists:
|
|
258
|
+
self.element_result_model.elements.append(new_element)
|
|
226
259
|
if is_ass:
|
|
227
260
|
if callable(getattr(SyncWebAssertion, self.element_model.ope_key, None)):
|
|
228
261
|
i.v = loc
|
|
229
262
|
elif callable(getattr(MangoAssertion(), self.element_model.ope_key, None)):
|
|
230
|
-
i.v =
|
|
263
|
+
i.v = element_text
|
|
231
264
|
else:
|
|
232
265
|
i.v = loc
|
|
233
|
-
|
|
234
|
-
for f, v in self.element_data.items():
|
|
235
|
-
if f == i.f:
|
|
236
|
-
i.v = self.base_data.test_data.replace(v)
|
|
237
|
-
i.v = self.base_data.test_data.replace(i.v)
|
|
266
|
+
i.v = self.base_data.test_data.replace(i.v)
|
|
238
267
|
|
|
239
268
|
except AttributeError as error:
|
|
240
269
|
self.base_data.log.debug(
|
|
@@ -126,7 +126,7 @@ class AsyncWebDevice(AsyncWebBrowser,
|
|
|
126
126
|
raise MangoAutomationError(*ERROR_MSG_0023)
|
|
127
127
|
if not ele_list:
|
|
128
128
|
raise MangoAutomationError(*ERROR_MSG_0023)
|
|
129
|
-
if not ele_list and _type == ElementOperationEnum.OPE
|
|
129
|
+
if not ele_list and _type == ElementOperationEnum.OPE:
|
|
130
130
|
raise MangoAutomationError(*ERROR_MSG_0029, value=(name, loc))
|
|
131
131
|
try:
|
|
132
132
|
count = len(ele_list)
|
|
@@ -1,21 +1,20 @@
|
|
|
1
1
|
mangoautomation/__init__.py,sha256=6nV7fyiPU5G-kWbrpCQUlkJdhJyPQh27qQaSvNvQkzQ,125
|
|
2
2
|
mangoautomation/enums/__init__.py,sha256=TZnjNeYQRysRolki82U0_s8BQamQ2EjlWFJ-RDDPel8,387
|
|
3
3
|
mangoautomation/enums/_base_enum.py,sha256=dpaXsdhWY08BhIzi1B1ksh_p18ZTmhWvTYhbd3n_ONQ,1176
|
|
4
|
-
mangoautomation/enums/_ui_enum.py,sha256=
|
|
4
|
+
mangoautomation/enums/_ui_enum.py,sha256=mT_MfQ7TEw-BgHIqH0wXTA_yVWsaWnd3iHSHi9E0pgA,4599
|
|
5
5
|
mangoautomation/exceptions/__init__.py,sha256=4CmTPcSFypENe3zXzsBUjA5MxXLugnP14dlakmItVjs,227
|
|
6
|
-
mangoautomation/exceptions/_error_msg.py,sha256=S51nDyUr0Jr4hE3i6D24JoGij_d_eeVNsUe2MTuRdJo,5341
|
|
7
6
|
mangoautomation/exceptions/_exceptions.py,sha256=BiyST1QPivpfIOuKn1gKhpXOyBv6gfip_KvlQuu8ctw,385
|
|
8
|
-
mangoautomation/exceptions/error_msg.py,sha256=
|
|
7
|
+
mangoautomation/exceptions/error_msg.py,sha256=0jSdviYbhJS0-xB-IvgRnxteM1ArIcFCIsDdbbVZ-RA,5332
|
|
9
8
|
mangoautomation/models/__init__.py,sha256=25zmLzbB4gObJ6nqN7jPYP9LcdlixDKBGVoc7JrwggI,323
|
|
10
|
-
mangoautomation/models/_ui_model.py,sha256=
|
|
9
|
+
mangoautomation/models/_ui_model.py,sha256=6v2nUL41ZJnHX_UEx_C7aAT-QYnDmtKtXyo7V4yvEKg,1787
|
|
11
10
|
mangoautomation/tools/__init__.py,sha256=J-uPfaTZMMo7CL2PY6_5qCO24iIBTtUJTuFXDJz_AZg,296
|
|
12
11
|
mangoautomation/tools/_mate.py,sha256=9lk_EJnAX_OyXbe5WacyHkkcEr2ScBgasl6eUnlklWA,405
|
|
13
12
|
mangoautomation/tools/_uiautodev.py,sha256=RMOQMXse744xwUDb1_l7qDv9mUiqZt1Gm5sbB-nlgDk,1388
|
|
14
13
|
mangoautomation/uidrive/__init__.py,sha256=3xD94fw5QQvBPMPDq2o-SiJI_zt0AdJuB_X0eAFth8g,430
|
|
15
|
-
mangoautomation/uidrive/_async_element.py,sha256
|
|
14
|
+
mangoautomation/uidrive/_async_element.py,sha256=-sLpkdiVeVfW1YkhJtgiO4_zRgS8XQ6bjkAKX3JywWA,15125
|
|
16
15
|
mangoautomation/uidrive/_base_data.py,sha256=xDjgBJ6CDFajUy18ft-NKe-7vKe7WtgMC9zV6gRrmPY,3946
|
|
17
16
|
mangoautomation/uidrive/_driver_object.py,sha256=7RGiAIPHU_bQtwVPEprnXt-HOzoKuKn_Bu2RZxjSAVs,2055
|
|
18
|
-
mangoautomation/uidrive/_sync_element.py,sha256=
|
|
17
|
+
mangoautomation/uidrive/_sync_element.py,sha256=9YVegi_mCqgb_JwoagsDqhQTmnAem4zrNzVphrqM24s,14861
|
|
19
18
|
mangoautomation/uidrive/android/__init__.py,sha256=HBYY1L-g7OASchquaUXH7NcpxXpuJVx6Zuw0JbNgq-Y,5524
|
|
20
19
|
mangoautomation/uidrive/android/_application.py,sha256=ic9RbiOAft3wWi6QH6PgcRVN8kiahe3wMyErxsHp3FU,2854
|
|
21
20
|
mangoautomation/uidrive/android/_assertion.py,sha256=ps6uBP4KxcBGJkrlG7m-Caq1rz4UfJhKUNU2YBetu-c,4349
|
|
@@ -32,7 +31,7 @@ mangoautomation/uidrive/pc/element.py,sha256=LdlWHhvXsaHH6jTp6nNrF81OWPtx81dct4y
|
|
|
32
31
|
mangoautomation/uidrive/pc/input_device.py,sha256=F6ZqKja3XkJww66x3l9Idha3R19D832J-5TfiKWmUso,353
|
|
33
32
|
mangoautomation/uidrive/pc/new_windows.py,sha256=lETHZa7cW8Z0iUShzgVTRxqivkYaOo8WIE58q_8KYfQ,2338
|
|
34
33
|
mangoautomation/uidrive/web/__init__.py,sha256=MgTklzty_SvX4UemCnqJuViq3cIjUgAjFoEtP-mcDWw,123
|
|
35
|
-
mangoautomation/uidrive/web/async_web/__init__.py,sha256=
|
|
34
|
+
mangoautomation/uidrive/web/async_web/__init__.py,sha256=1HoxtHLxVOSwrsquoUTwU29DJcYCcQg89p_DOyZ9tJU,8372
|
|
36
35
|
mangoautomation/uidrive/web/async_web/_assertion.py,sha256=2tPSGiJSKmrkiM0bvOd6nfTKTAjDAlosgXcn-oiN0zM,12820
|
|
37
36
|
mangoautomation/uidrive/web/async_web/_browser.py,sha256=mx1m4bPZSdvNOD_8V3gcFUjGMfU3oXj6IJJdlT4ukD0,5381
|
|
38
37
|
mangoautomation/uidrive/web/async_web/_customization.py,sha256=uw6p9uLHLXglgSkH4qjDl1v0iGlaNjvf8LljRH5cAHU,347
|
|
@@ -49,11 +48,11 @@ mangoautomation/uidrive/web/sync_web/_input_device.py,sha256=zPFd8xFuLeem9Io0ZBk
|
|
|
49
48
|
mangoautomation/uidrive/web/sync_web/_new_browser.py,sha256=APGUFhOVAW68x-6y9tQLZJkn2utfR-PrpjgP8WE38SE,6149
|
|
50
49
|
mangoautomation/uidrive/web/sync_web/_page.py,sha256=LC7FWr6Exv-KSiSU0y2Zxjd39_QLohe_UD5nvA8htUM,2045
|
|
51
50
|
tests/__init__.py,sha256=fdlqghHH7eXneovXweQjn6gVb8jwm6wprtPw5ksV_IA,350
|
|
52
|
-
tests/get_ope.py,sha256=
|
|
51
|
+
tests/get_ope.py,sha256=SVhSowMNa87hjzGhFlS0vp-t0RB9yKHOC52FsO93UG4,236
|
|
53
52
|
tests/test_ui_and.py,sha256=A_0pqG6s5Ts02He7P3NwuDSK3g9Q3VP1Sb_P8wq6g0Q,125
|
|
54
53
|
tests/test_ui_web.py,sha256=MFaUN8O5qKOMMgyk2eelhKZsYcSJm0Do6pCgsdBZEH4,2765
|
|
55
|
-
mangoautomation-1.
|
|
56
|
-
mangoautomation-1.
|
|
57
|
-
mangoautomation-1.
|
|
58
|
-
mangoautomation-1.
|
|
59
|
-
mangoautomation-1.
|
|
54
|
+
mangoautomation-1.1.2.dist-info/LICENSE,sha256=03WP-mgFmo8ofRYDe1HVDQUEUKQZ2q6P6Q-2A4c-46A,1085
|
|
55
|
+
mangoautomation-1.1.2.dist-info/METADATA,sha256=ZOiefw7Mzs6YIXY3XRHzGpHsVYRP250vfrKQsFOKIF8,815
|
|
56
|
+
mangoautomation-1.1.2.dist-info/WHEEL,sha256=yQN5g4mg4AybRjkgi-9yy4iQEFibGQmlz78Pik5Or-A,92
|
|
57
|
+
mangoautomation-1.1.2.dist-info/top_level.txt,sha256=g-uCmjvEODG8WFbmwbGM0-G0zHntHv8ZsS0PQRaMGtE,22
|
|
58
|
+
mangoautomation-1.1.2.dist-info/RECORD,,
|
tests/get_ope.py
CHANGED
|
@@ -3,10 +3,6 @@
|
|
|
3
3
|
# @Description:
|
|
4
4
|
# @Time : 2025-08-31 17:41
|
|
5
5
|
# @Author : 毛鹏
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
print(json.dumps(func_info, ensure_ascii=False, indent=4))
|
|
11
|
-
with open('ope.json', 'w') as f:
|
|
12
|
-
f.write(json.dumps(func_info, ensure_ascii=False, indent=4))
|
|
6
|
+
loc = 'await page.cdeadapage.'
|
|
7
|
+
cleaned_loc = loc.replace('page.', '').replace('await', '')
|
|
8
|
+
print(cleaned_loc)
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
# -*- coding: utf-8 -*-
|
|
2
|
-
# @Project: 芒果测试平台
|
|
3
|
-
# @Description: 错误消息统一管理
|
|
4
|
-
# @Time : 2024-02-01 10:00
|
|
5
|
-
# @Author : 毛鹏
|
|
6
|
-
|
|
7
|
-
ERROR_MSG_0001 = (4001, '')
|
|
8
|
-
ERROR_MSG_0002 = (4002, '')
|
|
9
|
-
ERROR_MSG_0003 = (4003, '')
|
|
10
|
-
ERROR_MSG_0004 = (4004, '')
|
|
11
|
-
ERROR_MSG_0005 = (4018, '断言失败,断言输入值是:空字符串、null或不满足函数接受类型')
|
|
12
|
-
ERROR_MSG_0006 = (4006, '')
|
|
13
|
-
ERROR_MSG_0007 = (4007, '安卓设备被关闭,请检查设备')
|
|
14
|
-
ERROR_MSG_0008 = (4008, '浏览器类型不正确,请联系管理员检查')
|
|
15
|
-
ERROR_MSG_0009 = (4009, '浏览器路径不正确,请手动设置一个正确的浏览器路径,现在的路径:{}')
|
|
16
|
-
ERROR_MSG_0010 = (4010, '浏览器被关闭,请不要手动关闭浏览器')
|
|
17
|
-
ERROR_MSG_0011 = (4011, '操作元素【{}】超时,请检查元素可见但是是否可操作或调整定位方式')
|
|
18
|
-
ERROR_MSG_0012 = (4012, '操作失败,请检查输入的值是否有空字符串,null或不满足传参的值')
|
|
19
|
-
ERROR_MSG_0013 = (
|
|
20
|
-
313, '打开url时超时,分为2个问题:1.启用的浏览器过多,应当减少浏览器并发个数;2.自行查看为啥60秒还未打开:{}')
|
|
21
|
-
ERROR_MSG_0014 = (4014, '')
|
|
22
|
-
ERROR_MSG_0015 = (4015, '没有操作的类型,请联系管理员进行排查问题')
|
|
23
|
-
ERROR_MSG_0016 = (4016, '')
|
|
24
|
-
ERROR_MSG_0017 = (4017, '断言失败: {}')
|
|
25
|
-
ERROR_MSG_0018 = (4018, '')
|
|
26
|
-
ERROR_MSG_0019 = (4019, '配置了sql断言,但是并没有配置mysql的数据库配置,请检查!')
|
|
27
|
-
ERROR_MSG_0020 = (4020, '没有更多的断言方式,请检查是否选择了非该设备类型的元素定位方式')
|
|
28
|
-
ERROR_MSG_0021 = (4021, '元素未找到,请检查断言前操作是否正常完成')
|
|
29
|
-
ERROR_MSG_0022 = (4022, '页面无此元素,请检查传入的元素是否正确')
|
|
30
|
-
ERROR_MSG_0023 = (4023, 'iframe中未找到此元素,请检查元素表达式是否是正确的')
|
|
31
|
-
ERROR_MSG_0024 = (4024, '上传文件的元素必须要是input标签中的')
|
|
32
|
-
ERROR_MSG_0025 = (4025, '无法元素对应的下标,请检查通过下标获取元素的数是否正确,当前元素个数:{}')
|
|
33
|
-
ERROR_MSG_0026 = (4026, '')
|
|
34
|
-
ERROR_MSG_0027 = (4027,
|
|
35
|
-
'您元素的操作内容中没有任何的数据,请检查:1.页面步骤详情中字段->元素操作值是否是空,是空可能是你删除了,也可能是执行器的操作选项没有同步需要点击执行器的同步发送缓存数据;2.元素表达式错误导致查询不到元素;')
|
|
36
|
-
ERROR_MSG_0028 = (4028, '')
|
|
37
|
-
ERROR_MSG_0029 = (4029, '页面无元素【{}】,表达式:{}')
|
|
38
|
-
ERROR_MSG_0030 = (4030, '断言时没有找到元素')
|
|
39
|
-
ERROR_MSG_0031 = (4031, '元素未找到准备进行断言获取元素文本类容异常')
|
|
40
|
-
ERROR_MSG_0032 = (4032, '元素【{}】的元素表达式定位有多个,或其他元素异常,请检查元素是否可用')
|
|
41
|
-
ERROR_MSG_0036 = (4036, '公共参数sql在数据库中查询不到结果,sql:{}')
|
|
42
|
-
ERROR_MSG_0038 = (4038, '公共参数的sql_key不是列表')
|
|
43
|
-
ERROR_MSG_0040 = (
|
|
44
|
-
340, '设备启动超时!请检查设备是否开启了:文件传输模式、开发者模式、usb调试,开启后请重新连接电脑,设备号:{}')
|
|
45
|
-
ERROR_MSG_0041 = (4041, '查找页面元素【{}】时直接失败,报错信息:{}')
|
|
46
|
-
ERROR_MSG_0042 = (4042, '实例化对象错误,设备信息是空无法实例化,请联系管理员检查')
|
|
47
|
-
ERROR_MSG_0043 = (4043, '元素【{}】可能不存在,报错信息:{}')
|
|
48
|
-
ERROR_MSG_0044 = (4044, '元素【{}】可能无法消失,报错信息:{}')
|
|
49
|
-
ERROR_MSG_0045 = (4045, '设备启动超时!请检查设备是否已成功连接电脑,设备号:{}')
|
|
50
|
-
ERROR_MSG_0046 = (4046, '您要测试的设备中,没有您输入的包名,请检查包名是否正确,或者设备是否安装了这个软件包')
|
|
51
|
-
ERROR_MSG_0047 = (4047, '')
|
|
52
|
-
ERROR_MSG_0048 = (4048, '选项发生错误,请在执行器点击发送缓存数据,然后重新修改步骤的操作!或联系管理员处理!')
|
|
53
|
-
ERROR_MSG_0049 = (4049, 'url格式错误,请检查url或者是选择的测试环境不正确')
|
|
54
|
-
ERROR_MSG_0050 = (4050, 'xpath定位未找到元素')
|
|
55
|
-
ERROR_MSG_0051 = (4051, '')
|
|
56
|
-
ERROR_MSG_0052 = (4052, '元素【{}】 进行断言时发生异常,请检查元素是否可以正常使用')
|
|
57
|
-
ERROR_MSG_0053 = (4053, '')
|
|
58
|
-
ERROR_MSG_0054 = (4054, '步骤是操作类型,但是你没有输入操作内容,请查看文档中对元素操作的介绍')
|
|
59
|
-
ERROR_MSG_0055 = (4055, '您的电脑未安装指定浏览器!')
|
|
60
|
-
ERROR_MSG_0056 = (4056, '输入的参数类型不正确,请检查操作输入框的类型是否正确')
|
|
61
|
-
ERROR_MSG_0057 = (
|
|
62
|
-
357,
|
|
63
|
-
'创建浏览器的时候失败,如果你开启了视频录制,则需要执行帮助文档中,windows部署的模块最后的安装playwright依赖。如果不是视频录制原因,则请发给管理员!')
|
|
64
|
-
ERROR_MSG_0058 = (4058, '电脑可能无网络,或者设置了代理,浏览器无法进行请求!')
|
|
65
|
-
ERROR_MSG_0059 = (4059, '输入内容的类型不正确')
|
|
66
|
-
ERROR_MSG_0060 = (4060, '请把元素等信息都发给管理员来解决这个报错,报错:{}')
|
|
67
|
-
ERROR_MSG_0061 = (4061, '')
|
|
68
|
-
ERROR_MSG_0062 = (4062, '请执行:playwright install 命令,安装符合要求的浏览器再运行命令行模式的执行器')
|
|
File without changes
|
|
File without changes
|
|
File without changes
|