@buaa_smat/hometrans 0.1.13 → 0.1.14
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.
- package/README.md +164 -112
- package/agents/build-fixer.md +384 -394
- package/agents/code-reviewer.md +240 -240
- package/agents/logic-coder.md +199 -199
- package/agents/logic-context-builder.md +194 -194
- package/agents/review-fixer.md +405 -405
- package/agents/self-test-fixer.md +296 -296
- package/agents/self-tester.md +393 -392
- package/agents/spec-generator.md +540 -540
- package/dist/cli/config-store.js +84 -8
- package/dist/cli/config.js +3 -3
- package/dist/cli/env-vars.js +129 -0
- package/dist/cli/init.js +272 -272
- package/dist/cli/uninstall.js +152 -17
- package/dist/context/index.js +10 -197
- package/env-requirements.json +3 -3
- package/package.json +1 -1
- package/resource/choose_editor.png +0 -0
- package/resource/common_config.png +0 -0
- package/resource/integration_test_config.png +0 -0
- package/resource/set_env.png +0 -0
- package/resource/ui_align_config.png +0 -0
- package/skills/hmos-batch-ui-align/SKILL.md +108 -98
- package/skills/hmos-batch-ui-align/references/conversion-procedure.md +180 -180
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-atomic-component-mapping-reference.md +2533 -2533
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-interaction-mapping-reference.md +555 -555
- package/skills/hmos-batch-ui-align/references/mappings/android-to-harmonyOS-ui-layout-mapping-reference.md +117 -117
- package/skills/hmos-batch-ui-align/references/mvvm/@Link/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/217/214/345/220/221/345/220/214/346/255/245.md +648 -648
- package/skills/hmos-batch-ui-align/references/mvvm/@Observed/350/243/205/351/245/260/345/231/250/345/222/214@ObjectLink/350/243/205/351/245/260/345/231/250/357/274/232/345/265/214/345/245/227/347/261/273/345/257/271/350/261/241/345/261/236/346/200/247/345/217/230/345/214/226.md +2088 -2088
- package/skills/hmos-batch-ui-align/references/mvvm/@Prop/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/215/225/345/220/221/345/220/214/346/255/245.md +1033 -1033
- package/skills/hmos-batch-ui-align/references/mvvm/@Provide/350/243/205/351/245/260/345/231/250/345/222/214@Consume/350/243/205/351/245/260/345/231/250/357/274/232/344/270/216/345/220/216/344/273/243/347/273/204/344/273/266/345/217/214/345/220/221/345/220/214/346/255/245.md +1183 -1183
- package/skills/hmos-batch-ui-align/references/mvvm/@State/350/243/205/351/245/260/345/231/250/357/274/232/347/273/204/344/273/266/345/206/205/347/212/266/346/200/201.md +576 -576
- package/skills/hmos-batch-ui-align/references/mvvm/@Track/350/243/205/351/245/260/345/231/250/357/274/232class/345/257/271/350/261/241/345/261/236/346/200/247/347/272/247/346/233/264/346/226/260.md +297 -297
- package/skills/hmos-batch-ui-align/references/mvvm/@Watch/350/243/205/351/245/260/345/231/250/357/274/232/347/212/266/346/200/201/345/217/230/351/207/217/346/233/264/346/224/271/351/200/232/347/237/245.md +395 -395
- package/skills/hmos-batch-ui-align/references/mvvm/AppStorage/357/274/232/345/272/224/347/224/250/345/205/250/345/261/200/347/232/204UI/347/212/266/346/200/201/345/255/230/345/202/250.md +902 -902
- package/skills/hmos-batch-ui-align/references/mvvm/Environment/357/274/232/350/256/276/345/244/207/347/216/257/345/242/203/346/237/245/350/257/242.md +106 -106
- package/skills/hmos-batch-ui-align/references/mvvm/LocalStorage/357/274/232/351/241/265/351/235/242/347/272/247UI/347/212/266/346/200/201/345/255/230/345/202/250.md +1178 -1178
- package/skills/hmos-batch-ui-align/references/mvvm/MVVM/346/250/241/345/274/217/357/274/210V1/357/274/211.md +911 -911
- package/skills/hmos-batch-ui-align/references/mvvm/PersistentStorage/357/274/232/346/214/201/344/271/205/345/214/226/345/255/230/345/202/250UI/347/212/266/346/200/201.md +354 -354
- package/skills/hmos-batch-ui-align/references/mvvm//347/256/241/347/220/206/345/272/224/347/224/250/346/213/245/346/234/211/347/232/204/347/212/266/346/200/201/346/246/202/350/277/260.md +11 -11
- package/skills/hmos-convert-pipeline/SKILL.md +429 -415
- package/skills/hmos-fix-build-errors/SKILL.md +272 -273
- package/skills/hmos-fix-build-errors/references/arkts-strict-patterns.md +219 -219
- package/skills/hmos-fix-build-errors/references/known-patterns.md +157 -157
- package/skills/hmos-fix-build-errors/references/rdb-entity-pattern.md +131 -131
- package/skills/hmos-incremental-ui-align/SKILL.md +219 -200
- package/skills/hmos-incremental-ui-align/diff_analysis.md +52 -52
- package/skills/hmos-incremental-ui-align/page_align.md +62 -62
- package/skills/hmos-incremental-ui-align/readme.md +237 -230
- package/skills/hmos-incremental-ui-align/references/Comparison_Template.md +2 -2
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Link/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/217/214/345/220/221/345/220/214/346/255/245.md +648 -648
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Observed/350/243/205/351/245/260/345/231/250/345/222/214@ObjectLink/350/243/205/351/245/260/345/231/250/357/274/232/345/265/214/345/245/227/347/261/273/345/257/271/350/261/241/345/261/236/346/200/247/345/217/230/345/214/226.md +2088 -2088
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Prop/350/243/205/351/245/260/345/231/250/357/274/232/347/210/266/345/255/220/345/215/225/345/220/221/345/220/214/346/255/245.md +1033 -1033
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Provide/350/243/205/351/245/260/345/231/250/345/222/214@Consume/350/243/205/351/245/260/345/231/250/357/274/232/344/270/216/345/220/216/344/273/243/347/273/204/344/273/266/345/217/214/345/220/221/345/220/214/346/255/245.md +1183 -1183
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@State/350/243/205/351/245/260/345/231/250/357/274/232/347/273/204/344/273/266/345/206/205/347/212/266/346/200/201.md +576 -576
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Track/350/243/205/351/245/260/345/231/250/357/274/232class/345/257/271/350/261/241/345/261/236/346/200/247/347/272/247/346/233/264/346/226/260.md +297 -297
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/@Watch/350/243/205/351/245/260/345/231/250/357/274/232/347/212/266/346/200/201/345/217/230/351/207/217/346/233/264/346/224/271/351/200/232/347/237/245.md +395 -395
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/AppStorage/357/274/232/345/272/224/347/224/250/345/205/250/345/261/200/347/232/204UI/347/212/266/346/200/201/345/255/230/345/202/250.md +902 -902
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/Environment/357/274/232/350/256/276/345/244/207/347/216/257/345/242/203/346/237/245/350/257/242.md +106 -106
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/LocalStorage/357/274/232/351/241/265/351/235/242/347/272/247UI/347/212/266/346/200/201/345/255/230/345/202/250.md +1178 -1178
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/MVVM/346/250/241/345/274/217V1.md +911 -911
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243/PersistentStorage/357/274/232/346/214/201/344/271/205/345/214/226/345/255/230/345/202/250UI/347/212/266/346/200/201.md +354 -354
- package/skills/hmos-incremental-ui-align/references/MVVM/345/274/200/345/217/221/346/226/207/346/241/243//347/256/241/347/220/206/345/272/224/347/224/250/346/213/245/346/234/211/347/232/204/347/212/266/346/200/201/346/246/202/350/277/260.md +11 -11
- package/skills/hmos-incremental-ui-align/references/UI_Analysis_Template.md +3 -3
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-atomic-component-mapping-reference.md +2533 -2533
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-interaction-mapping-reference.md +555 -555
- package/skills/hmos-incremental-ui-align/references/android-to-harmonyOS-ui-layout-mapping-reference.md +117 -117
- package/skills/hmos-incremental-ui-align/scripts/navigation-capure.md +37 -37
- package/skills/hmos-integration-test/SKILL.md +380 -369
- package/skills/hmos-integration-test/readme.md +309 -309
- package/skills/hmos-resources-convert/SKILL.md +623 -623
- package/skills/hmos-resources-convert/references/conversion-rules.md +663 -663
- package/skills/hmos-resources-convert/references/dependency-analysis-rules.md +388 -388
- package/skills/hmos-resources-convert/references/resource-mapping-rules.md +457 -457
- package/skills/hmos-resources-convert/references/xml-drawable-to-svg-rules.md +513 -513
- package/skills/hmos-spec-generate/SKILL.md +331 -331
- package/skills/hmos-spec-generate/references/android-platform-tokens.md +105 -105
- package/skills/hmos-spec-generate/references/spec-sample-1.md +78 -78
- package/skills/hmos-spec-generate/references/spec-sample-2.md +58 -58
- package/skills/hmos-spec-generate/references/spec-sample-3.md +116 -116
- package/skills/hmos-spec-generate/references/step4-report-template.md +33 -33
- package/tools/test-tools/autotest/README.md +33 -17
- package/tools/test-tools/autotest/self_test_runner.py +109 -15
- package/resource/hometrans_config.png +0 -0
- package/skills/hmos-incremental-ui-align/config-example.json +0 -11
- package/tools/test-tools/autotest/config.yaml.example +0 -58
package/README.md
CHANGED
|
@@ -3,19 +3,19 @@
|
|
|
3
3
|
|
|
4
4
|
[](LICENSE)
|
|
5
5
|
|
|
6
|
-
本文档为完整的
|
|
6
|
+
本文档为完整的Android到HarmonyOS迁移流程指导。
|
|
7
7
|
|
|
8
8
|
---
|
|
9
9
|
|
|
10
|
-
## 步骤
|
|
10
|
+
## 步骤0:安装依赖
|
|
11
11
|
|
|
12
|
-
### 0.1
|
|
12
|
+
### 0.1安装依赖并连接设备
|
|
13
13
|
|
|
14
|
-
按以下顺序安装(`ht init` 会逐项检测,并提示缺失项对各
|
|
14
|
+
按以下顺序安装(`ht init` 会逐项检测,并提示缺失项对各skill的影响)。各依赖下方均列出了「被依赖」的步骤:如果你不需要执行某依赖所对应的步骤,则可以不安装该依赖(相应skill会显示为受限或不可用,但不影响其它步骤)。
|
|
15
15
|
|
|
16
|
-
1. **安装
|
|
16
|
+
1. **安装DevEco Studio** — 下载地址:<https://developer.huawei.com/consumer/cn/download/>。安装完成后,配置以下 **PATH环境变量**(`<DevEco安装目录>` 指DevEco Studio的安装根目录):
|
|
17
17
|
|
|
18
|
-
| 工具 | PATH
|
|
18
|
+
| 工具 | PATH中加入的目录 |
|
|
19
19
|
|------|------------------|
|
|
20
20
|
| node / npm / npx | `<DevEco安装目录>\tools\node` |
|
|
21
21
|
| java | `<DevEco安装目录>\jbr\bin` |
|
|
@@ -24,113 +24,138 @@
|
|
|
24
24
|
验证方式:执行 `node -v`、`java -version`、`hdc -v` 均返回正常
|
|
25
25
|
|
|
26
26
|
被依赖:
|
|
27
|
-
- 步骤
|
|
28
|
-
- 步骤
|
|
29
|
-
- 步骤
|
|
30
|
-
- 步骤
|
|
31
|
-
2. **安装
|
|
27
|
+
- 步骤1资源转换(java可选,缺失时回退读取源码 `res/`)
|
|
28
|
+
- 步骤2.2增量UI对齐(必需)
|
|
29
|
+
- 步骤4逻辑代码转换流水线(必需,构建/评审修复)
|
|
30
|
+
- 步骤5自测回归(必需,真机调试)
|
|
31
|
+
2. **安装Android Studio** — 下载地址:<https://developer.android.com/studio>,并在 **SDK Manager** 中安装SDK。
|
|
32
32
|
|
|
33
33
|
验证方式:执行 `adb version` 返回正常
|
|
34
34
|
|
|
35
35
|
被依赖:
|
|
36
|
-
- 步骤
|
|
37
|
-
- 步骤
|
|
38
|
-
3. **安装
|
|
36
|
+
- 步骤2.1全量UI迁移(可选,仅自动抓取页面快照时需要)
|
|
37
|
+
- 步骤2.2增量UI对齐(必需)
|
|
38
|
+
3. **安装uv** — 安装指引:<https://docs.astral.sh/uv/getting-started/installation/>。
|
|
39
39
|
|
|
40
40
|
验证方式:执行 `uv --version` 返回正常
|
|
41
41
|
|
|
42
42
|
被依赖:
|
|
43
|
-
- 步骤
|
|
44
|
-
- 步骤
|
|
45
|
-
4. **安装
|
|
43
|
+
- 步骤4逻辑代码转换流水线的自测阶段(可经 `skip_test` 跳过)
|
|
44
|
+
- 步骤5自测回归(必需,AutoTest在uv下运行)
|
|
45
|
+
4. **安装python** — 安装指引:<https://www.python.org/downloads/>,要求 ≥ 3.10。
|
|
46
46
|
|
|
47
47
|
验证方式:执行 `python --version` 返回正常
|
|
48
48
|
|
|
49
49
|
被依赖:
|
|
50
|
-
- 步骤
|
|
51
|
-
- 步骤
|
|
50
|
+
- 步骤2.1全量UI迁移(必需,页面快照解析脚本)
|
|
51
|
+
- 步骤2.2增量UI对齐(必需,双端页面采集脚本)
|
|
52
52
|
5. **安装 [GitNexus](https://github.com/abhigyanpatwari/GitNexus)** — 执行 `npm install -g gitnexus && gitnexus setup`
|
|
53
53
|
|
|
54
54
|
验证方式:执行 `gitnexus --version` 返回正常
|
|
55
55
|
|
|
56
56
|
被依赖:
|
|
57
|
-
- 步骤
|
|
57
|
+
- 步骤3生成需求规格(必需)
|
|
58
58
|
6. **连接设备** — 连接安卓和鸿蒙真机,或启动模拟器
|
|
59
59
|
|
|
60
60
|
被依赖:
|
|
61
|
-
- 安卓真机/模拟器 — 步骤
|
|
62
|
-
- 鸿蒙真机/模拟器 — 步骤
|
|
63
|
-
- 鸿蒙**真机** — 步骤
|
|
61
|
+
- 安卓真机/模拟器 — 步骤2 UI迁移
|
|
62
|
+
- 鸿蒙真机/模拟器 — 步骤2.2增量UI对齐
|
|
63
|
+
- 鸿蒙**真机** — 步骤4流水线自测阶段、步骤5自测回归
|
|
64
64
|
|
|
65
|
-
### 0.2
|
|
65
|
+
### 0.2安装hometrans
|
|
66
66
|
|
|
67
67
|
执行 `npm install -g @buaa_smat/hometrans`。
|
|
68
68
|
|
|
69
69
|
验证方式:执行 `hometrans --version` 或 `ht --version` 返回正常
|
|
70
70
|
|
|
71
|
-
然后执行 `hometrans init` 或 `ht init
|
|
71
|
+
然后执行 `hometrans init` 或 `ht init`。
|
|
72
72
|
|
|
73
73
|
|
|
74
|
-
> 如果在
|
|
74
|
+
> 如果在PowerShell下运行,命令需要加上 `.cmd` 后缀,如 `hometrans.cmd --version`、`ht.cmd init`。
|
|
75
75
|
|
|
76
|
-
选择本地
|
|
76
|
+
### 0.2.1选择本地editor:
|
|
77
|
+

|
|
77
78
|
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-

|
|
83
|
-
|
|
84
|
-
- `DEVECO_SDK_HOME` — DevEco Studio 的 sdk 目录(唯一输入),其余路径由它派生并校验存在,示例:
|
|
79
|
+
### 0.2.2通用配置:
|
|
80
|
+

|
|
81
|
+
- `DEVECO_SDK_HOME` — DevEco Studio的sdk目录,其余路径由它派生并校验存在。示例:
|
|
85
82
|
|
|
86
83
|
```text
|
|
87
84
|
+ DEVECO_SDK_HOME : <DevEco安装目录>\sdk
|
|
88
|
-
+
|
|
85
|
+
+ DEVECO_HOME : <DevEco安装目录>
|
|
89
86
|
+ OHOS_SDK_PATH : <DevEco安装目录>\sdk\default\openharmony\ets
|
|
90
87
|
+ HMS_SDK_PATH : <DevEco安装目录>\sdk\default\hms\ets
|
|
91
88
|
```
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
- `GLM_API_KEY` — UI对齐中过程中GLM phone agent
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
89
|
+
### 0.2.3 UI对齐配置(如果不执行步骤2.2增量UI对齐,则可以不配置):
|
|
90
|
+

|
|
91
|
+
- `GLM_API_KEY` — UI对齐中过程中GLM phone agent所用的LLM API key。
|
|
92
|
+
|
|
93
|
+
申请方式:在[智谱官方网站](https://bigmodel.cn/apikey/platform)注册用户后,申请一个API KEY即可,调用的是免费的auto-glm模型,无需充值。
|
|
94
|
+
|
|
95
|
+
### 0.2.4集成测试配置(如果不执行步骤4的自测阶段与步骤5自测回归,则可以不配置):
|
|
96
|
+

|
|
97
|
+
- `autotest api_key` — 集成测试agent执行测试用例(真机自测)所用的多模态大模型API key。各配置项含义如下,`init` 环节只配置前4项,其余参数在`config.json`中配置。
|
|
98
|
+
|
|
99
|
+
| 参数 | 示例 / 默认值 | 含义 |
|
|
100
|
+
|-------------------|--------------|------|
|
|
101
|
+
| `name` | `""` | 多模态(视觉)模型的名字 |
|
|
102
|
+
| `base_url` | `""` | 模型API服务的基础地址 |
|
|
103
|
+
| `api_key` | (需填写) | 用于模型API请求认证的令牌 |
|
|
104
|
+
| `provider` | `openai` | 模型API服务的提供方标识,如openai;Azure服务填azure |
|
|
105
|
+
| `temperature` | `0.1` | 采样温度 |
|
|
106
|
+
| `top_p` | `0.9` | 核采样阈值 |
|
|
107
|
+
| `frequency_penalty` | `0.5` | 重复惩罚 |
|
|
108
|
+
| `device_sn` | `null` | 设备序列号;`null` 表示自动选用当前连接的设备 |
|
|
109
|
+
| `ip` | `127.0.0.1` | 设备连接IP(hdc) |
|
|
110
|
+
| `port` | `8710` | 设备连接端口(hdc) |
|
|
111
|
+
| `device_log_level` | `debug` | 设备日志级别:debug/info/... |
|
|
112
|
+
| `max_steps` | `50` | 单条用例最大执行步数 |
|
|
113
|
+
| `verbose` | `true` | 是否输出详细日志 |
|
|
114
|
+
| `lang` | `zh` | 输出语言:zh/en |
|
|
115
|
+
| `enable_preprocess` | `false` | 执行前是否先用unified_model把用例拆成步骤序列(多一次LLM调用,默认关) |
|
|
116
|
+
| `debug_mode` | `null` | 调试会话:`null` 关闭 / `memory` 内存 / `file` 存盘并跑完后起调试服务(:5000) |
|
|
117
|
+
|
|
118
|
+
### 0.2.5将配置信息添加到环境变量:
|
|
119
|
+

|
|
120
|
+
|
|
121
|
+
### 0.3准备项目
|
|
122
|
+
|
|
123
|
+
准备 **Android源项目** 与 **HarmonyOS目标项目目录**。
|
|
99
124
|
|
|
100
125
|
---
|
|
101
126
|
|
|
102
|
-
## 步骤
|
|
127
|
+
## 步骤1:资源转换(`hmos-resources-convert`)
|
|
103
128
|
|
|
104
|
-
> 📦 依赖:DevEco Studio
|
|
129
|
+
> 📦 依赖:DevEco Studio中的java(可选,缺失时回退读取源码 `res/`)。
|
|
105
130
|
|
|
106
|
-
> ⚠️ 提示:如果步骤
|
|
131
|
+
> ⚠️ 提示:如果步骤2的UI迁移采用**全量迁移**(`hmos-batch-ui-align`),则跳过当前步骤(全量UI迁移内部已包含资源转换)。
|
|
107
132
|
|
|
108
133
|
```
|
|
109
|
-
/hmos-resources-convert
|
|
134
|
+
/hmos-resources-convert android_project_dir=<安卓项目路径> harmony_project_dir=<鸿蒙项目路径> resource_mapping_path=<资源映射文档路径>
|
|
110
135
|
```
|
|
111
136
|
|
|
112
137
|
**输入参数**
|
|
113
138
|
|
|
114
139
|
| 参数 | 类型 | 说明 |
|
|
115
140
|
|------|------|------|
|
|
116
|
-
| `
|
|
117
|
-
| `
|
|
118
|
-
| `resource_mapping_path` | **必选** | Android ↔ HarmonyOS
|
|
119
|
-
| `
|
|
141
|
+
| `android_project_dir` | **必选** | Android项目根目录路径(含 `build.gradle` 或 `build.gradle.kts`) |
|
|
142
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目输出路径 |
|
|
143
|
+
| `resource_mapping_path` | **必选** | Android ↔ HarmonyOS资源映射文档的完整输出路径(`.md`) |
|
|
144
|
+
| `apk_path` | 可选 | Android APK文件路径;提供后跳过Gradle构建和apktool解包,直接从APK提取资源 |
|
|
120
145
|
|
|
121
146
|
**输出产物**
|
|
122
147
|
|
|
123
148
|
| 产物 | 位置 | 说明 |
|
|
124
149
|
|------|------|------|
|
|
125
|
-
| `resources/` 目录 | HarmonyOS
|
|
126
|
-
| 资源映射文档 | `resource_mapping_path` | Android ↔ HarmonyOS
|
|
127
|
-
| 转换报告 | HarmonyOS
|
|
150
|
+
| `resources/` 目录 | HarmonyOS项目下 | 转换后的HarmonyOS资源(strings、colors、dimensions、images等) |
|
|
151
|
+
| 资源映射文档 | `resource_mapping_path` | Android ↔ HarmonyOS资源条目映射(`.md`) |
|
|
152
|
+
| 转换报告 | HarmonyOS项目下 | 资源转换过程与统计 |
|
|
128
153
|
|
|
129
154
|
---
|
|
130
155
|
|
|
131
|
-
## 步骤
|
|
156
|
+
## 步骤2:UI迁移
|
|
132
157
|
|
|
133
|
-
### 2.1
|
|
158
|
+
### 2.1全量迁移(`hmos-batch-ui-align`)
|
|
134
159
|
|
|
135
160
|
> 📦 依赖:python(必需,页面快照解析脚本);Android Studio + 安卓真机/模拟器(可选,仅自动抓取页面快照时需要)。
|
|
136
161
|
|
|
@@ -142,97 +167,124 @@
|
|
|
142
167
|
|
|
143
168
|
| 参数 | 类型 | 说明 |
|
|
144
169
|
|------|------|-------------------------------------------------------------------------------------------------------------|
|
|
145
|
-
| `android_project_dir` | **必选** | Android
|
|
146
|
-
| `harmony_project_dir` | **必选** | HarmonyOS
|
|
147
|
-
| `ui_info_root` | 可选 | 包含 `page_NNNN_ActivityName` 格式子目录的父目录(每子目录含 `meta.json` + `view.xml` + 可选 `screenshot.png`);不提供时自动通过
|
|
170
|
+
| `android_project_dir` | **必选** | Android项目根目录路径 |
|
|
171
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目输出路径 |
|
|
172
|
+
| `ui_info_root` | 可选 | 包含 `page_NNNN_ActivityName` 格式子目录的父目录(每子目录含 `meta.json` + `view.xml` + 可选 `screenshot.png`);不提供时自动通过adb抓取 |
|
|
148
173
|
| `pages` | 可选 | 显式列出的页面子集(不提供则处理所有页面) |
|
|
149
174
|
|
|
150
175
|
**输出产物**
|
|
151
176
|
|
|
152
177
|
| 产物 | 位置 | 说明 |
|
|
153
178
|
|------|------|------|
|
|
154
|
-
| ArkTS
|
|
155
|
-
| 资源文件 | HarmonyOS
|
|
156
|
-
| 批量转换报告 | HarmonyOS
|
|
179
|
+
| ArkTS页面文件 | HarmonyOS项目下 | 由Android Activity转换生成的ArkTS页面 |
|
|
180
|
+
| 资源文件 | HarmonyOS项目下 | 页面所需资源(含全量迁移内部触发的资源转换产物) |
|
|
181
|
+
| 批量转换报告 | HarmonyOS项目下 | 各页面转换结果、缺陷与统计 |
|
|
157
182
|
|
|
158
|
-
### 2.2
|
|
183
|
+
### 2.2增量对齐(`hmos-incremental-ui-align`,按需)
|
|
159
184
|
|
|
160
185
|
> 📦 依赖:DevEco Studio、Android Studio、python(必需,双端页面采集脚本);安卓真机/模拟器 + 鸿蒙真机/模拟器(必需)。
|
|
161
186
|
|
|
162
|
-
> 👤 前置:需用户预先配置好 `config.json`(双端 app 包名/工程路径等,参考 skill 目录下 `config-example.json`;`ht init` 已预置并填充 `glm_api_key` / `hmos_sdk_dir`)。对齐目标在消息中描述,如 "帮我对齐设置页面的关于页面"。
|
|
163
|
-
|
|
164
187
|
```
|
|
165
|
-
/hmos-incremental-ui-align
|
|
188
|
+
/hmos-incremental-ui-align android_project_dir=<安卓工程路径> harmony_project_dir=<鸿蒙工程路径>
|
|
166
189
|
```
|
|
167
190
|
|
|
168
191
|
**输入参数**
|
|
169
192
|
|
|
170
193
|
| 参数 | 类型 | 说明 |
|
|
171
194
|
|------|------|------|
|
|
172
|
-
| `
|
|
195
|
+
| `android_project_dir` | 必填 | 安卓源码根目录;用于自动解析安卓app名/包名 |
|
|
196
|
+
| `harmony_project_dir` | 必填 | 鸿蒙工程根目录(会被直接修改);用于自动解析鸿蒙app名/包名 |
|
|
197
|
+
| `capture_output_dir` | 可选 | 采集产物输出目录,默认 `<harmony_project_dir>/.hometrans/capture_output` |
|
|
173
198
|
|
|
174
199
|
**输出产物**
|
|
175
200
|
|
|
176
201
|
| 产物 | 位置 | 说明 |
|
|
177
202
|
|------|------|------|
|
|
178
|
-
| 修改后的
|
|
179
|
-
| 双端页面截图与视图树 | `capture_output_dir` | Android/HarmonyOS
|
|
203
|
+
| 修改后的ArkTS页面文件 | HarmonyOS项目下 | 对齐目标页面后的代码改动 |
|
|
204
|
+
| 双端页面截图与视图树 | `capture_output_dir` | Android/HarmonyOS两侧 `screenshot.png` + 视图树文件 |
|
|
180
205
|
| 对齐差异/修复报告 | `capture_output_dir` | 差异分析与修复说明 |
|
|
181
206
|
|
|
182
207
|
---
|
|
183
208
|
|
|
184
|
-
## 步骤
|
|
209
|
+
## 步骤3:生成需求规格(`hmos-spec-generate`)
|
|
185
210
|
|
|
186
211
|
> 📦 依赖:GitNexus(必需)。
|
|
187
212
|
|
|
188
|
-
> 👤 前置:用户编写 REQ
|
|
213
|
+
> 👤 前置:用户编写 `REQ.txt` 文件 — 以自然语言描述原始需求,如有多个需求则在文件中使用空行进行分隔,需求中建议包含页面跳转路径的说明以及业务逻辑的描述。
|
|
214
|
+
|
|
215
|
+
`REQ.txt` 示例:
|
|
216
|
+
|
|
217
|
+
```text
|
|
218
|
+
设置-歌词-歌词界面-卡拉OK歌词动画兼容策略(播放页歌词设置同步实现)
|
|
219
|
+
逐字歌词效果,默认是当前行
|
|
220
|
+
1,当前行:只为前歌曲的歌词中有单字时间戳的歌词行显示逐字特效
|
|
221
|
+
2,扩展全部:当前歌曲的歌词中只要有一行歌词带单字时间戳,所有歌词行都显示逐字特效
|
|
222
|
+
3,总是:当前歌曲所有歌词行都显示逐字特效
|
|
223
|
+
|
|
224
|
+
设置-用户界面-圆形播放封面(圆形支持旋转)
|
|
225
|
+
开关,默认关闭,打开后,在播放页以圆形展示封面,并且自动旋转
|
|
226
|
+
|
|
227
|
+
设置-用户界面-允许不规则封面(支持长方形封面,参考无归)
|
|
228
|
+
开关,默认打开,播放页封面以大小一致的正方形展示,打开后,在播放页封面以原始样式展示
|
|
229
|
+
|
|
230
|
+
设置-歌词-悬浮窗状态栏歌词
|
|
231
|
+
开关 ,默认关闭,打开前需要申请悬浮窗权限,打开后在悬浮窗滚动展示歌词
|
|
232
|
+
1,左右位置:默认0%
|
|
233
|
+
2,上下位置:默认0px
|
|
234
|
+
3,宽度:默认150dp
|
|
235
|
+
4,大小:默认14.0dp
|
|
236
|
+
5,选择颜色:默认蓝色
|
|
237
|
+
6,歌词文本居左对齐:开关 默认关闭,歌词在设置的宽度内中对齐
|
|
238
|
+
7,状态栏歌词不显示翻译:开关 默认关闭
|
|
239
|
+
8,在播放界面隐藏:开关 默认关闭 打开后如果切换到播放页,则不在悬浮窗区域显示歌词
|
|
240
|
+
```
|
|
189
241
|
|
|
190
242
|
```
|
|
191
|
-
/hmos-spec-generate
|
|
243
|
+
/hmos-spec-generate requirement_description_file=<需求描述文件路径> android_project_dir=<安卓项目路径> spec_output_dir=<规格输出目录>
|
|
192
244
|
```
|
|
193
245
|
|
|
194
246
|
**输入参数**
|
|
195
247
|
|
|
196
248
|
| 参数 | 类型 | 说明 |
|
|
197
249
|
|------|------|------|
|
|
198
|
-
| `
|
|
199
|
-
| `
|
|
200
|
-
| `
|
|
250
|
+
| `requirement_description_file` | **必选** | 需求描述 `.txt` 文件路径(每段以 `REQ` 开头,空行分隔) |
|
|
251
|
+
| `android_project_dir` | **必选** | Android项目根目录路径(必须位于Git仓库内) |
|
|
252
|
+
| `spec_output_dir` | **必选** | 规格文档输出目录(自动创建;每个REQ生成 `<feature>-SPEC.md` + `.trace/<feature>.md`) |
|
|
201
253
|
|
|
202
254
|
**输出产物**
|
|
203
255
|
|
|
204
256
|
| 产物 | 位置 | 说明 |
|
|
205
257
|
|------|------|------|
|
|
206
|
-
| `<feature>-SPEC.md` | `
|
|
207
|
-
| `.trace/<feature>.md` | `
|
|
258
|
+
| `<feature>-SPEC.md` | `spec_output_dir` | 每个REQ对应一份原子场景规格文档 |
|
|
259
|
+
| `.trace/<feature>.md` | `spec_output_dir/.trace/` | 每个REQ对应的代码trace(GitNexus探索结果) |
|
|
208
260
|
|
|
209
261
|
---
|
|
210
262
|
|
|
211
|
-
## 步骤
|
|
263
|
+
## 步骤4:逻辑代码转换流水线(`hmos-convert-pipeline`)
|
|
212
264
|
|
|
213
|
-
> 📦 依赖:DevEco Studio(必需,构建/评审修复);uv + 鸿蒙真机(
|
|
265
|
+
> 📦 依赖:DevEco Studio(必需,构建/评审修复);uv + 鸿蒙真机(集成测试阶段需要,可经 `skip_test` 跳过)。
|
|
214
266
|
|
|
215
267
|
> 👤 前置:
|
|
216
|
-
> 1.
|
|
217
|
-
> 2.
|
|
268
|
+
> 1. 如果执行集成测试,需要**编写测试用例文档**输出前置测试用例(非必须,用于测试用例的环境准备等)通过pre_test_case_path参数传递,测试用例通过test_case_path参数传递。
|
|
269
|
+
> 2. 如果执行集成测试,需要**连接HarmonyOS真机**并且在DevEco Studio中[**配置签名**](https://developer.huawei.com/consumer/cn/doc/harmonyos-guides/networkboost-preparations#%E9%85%8D%E7%BD%AE%E7%AD%BE%E5%90%8D)。
|
|
218
270
|
|
|
219
271
|
```
|
|
220
|
-
/hmos-convert-pipeline
|
|
272
|
+
/hmos-convert-pipeline android_project_dir=<安卓项目路径> harmony_project_dir=<鸿蒙项目路径> spec_file_path=<需求规格文档路径>
|
|
221
273
|
```
|
|
222
274
|
|
|
223
275
|
**输入参数**
|
|
224
276
|
|
|
225
277
|
| 参数 | 类型 | 说明 |
|
|
226
278
|
|------|------|------|
|
|
227
|
-
| `
|
|
228
|
-
| `
|
|
229
|
-
| `
|
|
230
|
-
| `
|
|
231
|
-
| `
|
|
232
|
-
| `
|
|
233
|
-
| `
|
|
234
|
-
| `
|
|
235
|
-
| `
|
|
279
|
+
| `android_project_dir` | **必选** | Android项目根目录路径 |
|
|
280
|
+
| `harmony_project_dir` | **必选** | HarmonyOS项目根目录路径 |
|
|
281
|
+
| `spec_file_path` | **必选** | 需求规格文档路径(各阶段直接读取,无需复制到输出目录) |
|
|
282
|
+
| `assets_output_path` | 可选 | 输出/报告文件存放目录(默认鸿蒙工程下 `.hometrans`,自动创建) |
|
|
283
|
+
| `test_case_path` | 可选 | 自测用例文件路径(默认读输出目录下 `test_case.md`;不存在则跳过自测循环) |
|
|
284
|
+
| `pre_test_case_path` | 可选 | 前置用例文件路径(默认读输出目录下 `pre_test_case.md`;存在才传给自测) |
|
|
285
|
+
| `max_rounds_review` | 可选 | 代码检视循环最大轮数(正整数 `>= 1`,默认 `2`) |
|
|
286
|
+
| `max_rounds_test` | 可选 | 自测循环最大轮数(正整数 `>= 1`,默认 `2`) |
|
|
287
|
+
| `skip_test` | 可选 | `true` 跳过集成测试阶段(无真机验证环境时设为 `true`,默认 `false`) |
|
|
236
288
|
|
|
237
289
|
> 参数按位置传递:要传某个可选参数,需先显式给出它前面的所有可选参数。
|
|
238
290
|
|
|
@@ -240,57 +292,57 @@
|
|
|
240
292
|
|
|
241
293
|
| 产物 | 位置 | 说明 |
|
|
242
294
|
|------|------|------|
|
|
243
|
-
| 已签名
|
|
244
|
-
| `pipeline-manifest.md` | `
|
|
245
|
-
| 构建阶段报告 | `
|
|
246
|
-
| 评审阶段报告 | `
|
|
247
|
-
| 自测阶段报告 | `
|
|
295
|
+
| 已签名HAP | HarmonyOS项目下 `build/` | 通过自测/评审循环后的最终发布包 |
|
|
296
|
+
| `pipeline-manifest.md` | `assets_output_path` | 流水线清单:阶段耗时、轮数、缺陷统计 |
|
|
297
|
+
| 构建阶段报告 | `assets_output_path` | 编译错误与修复记录 |
|
|
298
|
+
| 评审阶段报告 | `assets_output_path` | 代码检视报告与修复记录 |
|
|
299
|
+
| 自测阶段报告 | `assets_output_path` | 测试结果、失败用例与修复记录 |
|
|
248
300
|
|
|
249
301
|
---
|
|
250
302
|
|
|
251
|
-
## 步骤
|
|
303
|
+
## 步骤5:集成测试(`hmos-integration-test`,已包含在步骤4,也可以单独运行)
|
|
252
304
|
|
|
253
|
-
> 📦 依赖:DevEco Studio(必需,真机调试);uv(必需,AutoTest
|
|
305
|
+
> 📦 依赖:DevEco Studio(必需,真机调试);uv(必需,AutoTest在uv下运行);鸿蒙真机(必需)。
|
|
254
306
|
|
|
255
307
|
```
|
|
256
|
-
/hmos-integration-test
|
|
308
|
+
/hmos-integration-test test_case_path=<测试用例路径> hap_path=<签名HAP路径>
|
|
257
309
|
```
|
|
258
310
|
|
|
259
311
|
**输入参数**
|
|
260
312
|
|
|
261
313
|
| 参数 | 类型 | 说明 |
|
|
262
314
|
|------|------|------|
|
|
263
|
-
| `
|
|
264
|
-
| `
|
|
265
|
-
| `
|
|
266
|
-
| `
|
|
267
|
-
| `
|
|
268
|
-
| `
|
|
315
|
+
| `test_case_path` | **必选** | `test_case.md` 测试用例文件路径 |
|
|
316
|
+
| `hap_path` | **必选** | 已签名的HAP文件路径 |
|
|
317
|
+
| `output_path` | 可选 | 报告输出目录 |
|
|
318
|
+
| `pre_test_case_path` | 可选 | 前置用例文件路径 |
|
|
319
|
+
| `android_project_dir` | 可选 | Android项目路径(修复时参考) |
|
|
320
|
+
| `max_rounds` | 可选 | 测试-修复循环最大轮数(默认 `3`) |
|
|
269
321
|
|
|
270
322
|
**输出产物**
|
|
271
323
|
|
|
272
324
|
| 产物 | 位置 | 说明 |
|
|
273
325
|
|------|------|------|
|
|
274
|
-
| 测试报告 | `
|
|
275
|
-
| 失败用例详情 | `
|
|
276
|
-
| 修复建议 | `
|
|
326
|
+
| 测试报告 | `output_path` | 测试结果、通过/失败用例统计 |
|
|
327
|
+
| 失败用例详情 | `output_path` | 失败用例的复现步骤与日志 |
|
|
328
|
+
| 修复建议 | `output_path` | 针对失败用例的修复方向(进入测试-修复循环时生效) |
|
|
277
329
|
|
|
278
330
|
---
|
|
279
331
|
|
|
280
|
-
## 步骤
|
|
332
|
+
## 步骤6:人工验收(👤 用户介入)
|
|
281
333
|
|
|
282
334
|
**输入**
|
|
283
335
|
|
|
284
336
|
| 输入 | 说明 |
|
|
285
337
|
|------|------|
|
|
286
338
|
| `pipeline-manifest.md` | 流水线清单与缺陷统计 |
|
|
287
|
-
| 自测报告 | 步骤
|
|
288
|
-
| 已签名
|
|
339
|
+
| 自测报告 | 步骤5/步骤4自测阶段产出的测试报告 |
|
|
340
|
+
| 已签名HAP | 步骤4流水线产出的最终发布包 |
|
|
289
341
|
|
|
290
342
|
**输出**
|
|
291
343
|
|
|
292
344
|
| 产物 | 说明 |
|
|
293
345
|
|------|------|
|
|
294
|
-
| 可发布的
|
|
346
|
+
| 可发布的HarmonyOS应用 | 已处理报告中的遗留缺陷/TODO,通过核心场景走查 |
|
|
295
347
|
|
|
296
|
-
通读 `pipeline-manifest.md` 与自测报告,真机走查核心场景,处理报告中的遗留缺陷/TODO
|
|
348
|
+
通读 `pipeline-manifest.md` 与自测报告,真机走查核心场景,处理报告中的遗留缺陷/TODO后发布。
|