221 lines
4.7 KiB
Markdown
221 lines
4.7 KiB
Markdown
## 自动化测试工具脚本
|
||
|
||
### 0. 用前须知
|
||
|
||
1. 调用必须在rokae目录下执行
|
||
2. python3.13开发,使用时需版本匹配,并安装requirements.txt中的依赖库
|
||
|
||
### 1. socket通信(支持xService)
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
import time
|
||
|
||
hr = openapi.HmiRequest()
|
||
time.sleep(2)
|
||
hr.close()
|
||
msg_id = hr.exec_cmd("controller.get_params")
|
||
record = hr.get_from_id(msg_id)
|
||
print(f"version = {eval(record)['data']['version']}")
|
||
```
|
||
|
||
> #### **B. 目前支持(后续可按需增加)**
|
||
|
||
```
|
||
collision.get_params
|
||
collision.set_params
|
||
controller.get_params
|
||
controller.heart
|
||
controller.reboot
|
||
controller.set_params
|
||
device.get_params
|
||
diagnosis.get_params
|
||
diagnosis.open
|
||
diagnosis.save
|
||
diagnosis.set_params
|
||
drag.get_params
|
||
drag.set_params
|
||
fieldbus_device.get_params
|
||
fieldbus_device.load_cfg
|
||
fieldbus_device.set_params
|
||
io_device.load_cfg
|
||
jog.get_params
|
||
jog.set_params
|
||
jog.start
|
||
log_code.data.code_list
|
||
log_code.data
|
||
modbus.get_params
|
||
modbus.get_values
|
||
modbus.load_cfg
|
||
modbus.set_params
|
||
move.get_joint_pos
|
||
move.get_monitor_cfg
|
||
move.get_params
|
||
move.get_pos
|
||
move.get_quickstop_distance
|
||
move.get_quickturn_pos
|
||
move.quick_turn
|
||
move.set_monitor_cfg
|
||
move.set_params
|
||
move.set_quickstop_distance
|
||
move.set_quickturn_pos
|
||
move.stop
|
||
overview.get_autoload
|
||
overview.get_cur_prj
|
||
overview.reload
|
||
overview.set_autoload
|
||
register.set_value
|
||
rl_task.pp_to_main
|
||
rl_task.run
|
||
rl_task.set_run_params
|
||
rl_task.stop
|
||
safety.safety_area.overall_enable
|
||
safety.safety_area.safety_area_enable
|
||
safety.safety_area.set_param
|
||
safety.safety_area.signal_enable
|
||
safety_area_data
|
||
servo.clear_alarm
|
||
socket.get_params
|
||
socket.set_params
|
||
soft_limit.get_params
|
||
soft_limit.set_params
|
||
state.get_state
|
||
state.get_tp_mode
|
||
state.set_tp_mode
|
||
state.switch_auto
|
||
state.switch_manual
|
||
state.switch_motor_off
|
||
state.switch_motor_on
|
||
system_io.query_configuration
|
||
system_io.query_event_cfg
|
||
system_io.update_configuration
|
||
```
|
||
|
||
### 2. modbus通信
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
md = openapi.ModbusRequest()
|
||
md.r_switch_auto()
|
||
_ = md.w_sta_tcp_vel
|
||
print(_)
|
||
```
|
||
|
||
> #### **B. 目前支持**
|
||
|
||
自定义的寄存器读写操作,以及98%以上的预置modbus功能码。
|
||
|
||
### 3. 外部通信
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
ec = openapi.EcRequest()
|
||
_ = ec.get_cart_pos
|
||
ec.close_reduced_mode()
|
||
```
|
||
|
||
> #### **B. 目前支持**
|
||
|
||
包括状态和控制操作,覆盖98%以上的外部通信功能。
|
||
|
||
### 4. 文件传输
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
pd = openapi.PreDos()
|
||
downloads = "C:/Users/Administrator/Downloads"
|
||
pd.pull_prj_from_server("aio", downloads)
|
||
local_prj = downloads + "/aio.zip"
|
||
pd.push_prj_to_server(local_prj)
|
||
|
||
local_file = downloads + "/aio.txt"
|
||
server_file = "/tmp/aio.txt"
|
||
pd.push_file_to_server(local_file, server_file)
|
||
pd.pull_file_from_server(server_file, local_file)
|
||
```
|
||
|
||
> #### **B. 目前支持(除了prj_name为工程名,其他均为对应系统下的绝对路径)**
|
||
|
||
- push_prj_to_server(prj_file)
|
||
- pull_prj_from_server(prj_name, local_prj_path)
|
||
- push_file_to_server(local_file, server_file)
|
||
- pull_file_from_server(server_file, local_file)
|
||
|
||
### 5. 初始化以及固件更新
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
ri = openapi.RobotInit()
|
||
ri.robot_init()
|
||
ri.fw_updater("C:/Users/Administrator/Downloads/FW/v3.1.1.rpa")
|
||
ri.fw_updater("C:/Users/Administrator/Downloads/XMS3-R580-W4G3C2_ME_AE_SS_xC.v3.1.0.R0.rpa")
|
||
```
|
||
|
||
> #### **B. 目前支持**
|
||
|
||
- robot_init() # 初始化机器人,新建modbus设备,并配置寄存器文件,打开IO设备中的modbus设备
|
||
- fw_updater(fw_file) # 目前仅测试支持机型文件和控制器
|
||
|
||
### 6. 升级协议
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
ur = openapi.UpgradeRequest()
|
||
ur.version_query()
|
||
ur.robot_reboot()
|
||
```
|
||
|
||
> #### **B. 目前支持**
|
||
|
||
- erase_cfg
|
||
- clear_rubbish
|
||
- soft_reboot
|
||
- version_query
|
||
- robot_reboot
|
||
- backup_origin
|
||
- origin_recovery
|
||
|
||
### 7. 生成运动轨迹
|
||
|
||
> #### **A. 调用方法示例**
|
||
|
||
```python
|
||
from codes import openapi
|
||
|
||
hr = openapi.HmiRequest()
|
||
pd = openapi.PreDos() # 如下三行首次运行时,必须打开
|
||
ri = openapi.RobotInit(hr, pd) # 非首次重复运行时,可以注释
|
||
ri.robot_init() # 注释后可以节省运行时间
|
||
md = openapi.ModbusRequest()
|
||
|
||
pt = openapi.PlotTrajectory(hr, md, prj_name="arc_test_M", tasks=["task0", ], curve_name="hw_cart_pos_feedback_tcp_in_world")
|
||
pt.draw_traj()
|
||
```
|
||
|
||
> #### **B. 目前支持**
|
||
|
||
自动保存3D空间运动曲线图到本地的trajectory.html文件
|
||
|
||
- hw_cart_pos_feedback_motorside
|
||
- hw_cart_pos_feedback_linkside
|
||
- hw_cart_pos_feedback_encoder_tcp_in_world
|
||
- hw_cart_pos_feedback_flan_in_world
|
||
- hw_cart_pos_feedback_tcp_in_world
|