flutter开发流程工具
Project description
帮助文档
-h or --help: 输出帮助文档
-c : 对所有模块执行自定义 git 命令, 例如: -c git status.
项目初始化
------------------------------------------------------------------------
init 请确保已配置initial_config.json文件,然后会执行以下步骤:
1.clone所有配置的模块
2.切换所有模块的分支到配置的feature分支
3.重写所有依赖为本地依赖
deps 修改initial_config.json文件后,执行该命令,更新依赖
upgrade 升级tdf_tools包版本
module-update 更新存储项目git信息的json文件
open 打开vscode,同时将所有模块添加入vscode中
git相关
------------------------------------------------------------------------
status 聚合展示所有模块的仓库状态
commit 对所有模块执行add 和 commit
diff 对所有模块执行 git diff --name-only 当前分支..master
diff [branch] 对所有模块执行 git diff --name-only 当前分支..[branch]
pull or sync 对所有模块执行 git pull
checkout 对所有模块执行 git checkout 切换到配置在initial_config.json中的feature分支
checkout [branch] 对所有模块执行 git checkout branch
cfb [branch] -p 对所有模块执行 git checkout 并push到远程,跟踪来自 'origin' 的远程分支
merge 对所有模块执行 git merge
branch 聚合展示所有模块的当前分支
push 对所有模块执行 git push origin 当前分支
mr -c sourceBranch targetBranch 对所有模块提交一个merge request 源分支sourceBranch,目标分支targetBranch
插件安装方式
安装python包
pip3 install tdf-tools --user
安装并更新python包
pip3 install --upgrade tdf-tools --user
安装测试环境python包
pip3 install -i https://test.pypi.org/simple/ tdf-tools --user
安装并更新测试环境python包
pip3 install --upgrade -i https://test.pypi.org/simple/ tdf-tools --user
工具使用流程说明
1.准备工作
在~目录下,创建.tdf_tools_config文件并配置相关必需属性如下
git_private_token=***
-
git_private_token是gitlab的token
获取途径:进入gitlab页面,点击右上角头像,选择Preferences,选择左侧列表中的AccessToken进行创建
上述步骤如果没有做,会在使用插件时,会有提示
2.初始化
i.进入壳目录(确保执行命令在壳目录内)
ii.执行tdf_tools init
- 判断当前目录是否存在tdf_cache,若不存在,则会自动创建tdf_cache
- 自动读取当前壳模块名称,写入initial_config.json配置文件;
- 读取当前壳分支,写入initial_config.json配置文件;
- 交互式提示用户输入需要开发的模块名并写入initial_config.json配置文件的moduleNameList列表字段中
- !退出,即输入完成
- 自动clone所有开发模块到
../.tdf_flutter隐藏目录中; - 将所有开发模块分支切换至与壳一致;
- 自动分析依赖树,并由下至上对所有模块自动执行
flutter pub upgrade;
iii.开发过程中
1.开发模块添加
- 若是有新模块需要添加入开发模块中,可直接修改initial_config.json配置文件,修改moduleNameList字段;
- 执行tdf_tools deps更新依赖
2.新开发模块添加
- 添加新模块后,会提示找不到模块,实际查找的是
tdf_cache文件夹中的module_config.json文件; - 如果没有找到该模块,则可以执行
tdf_tools module-update,更新远程module_config.json文件; - 删掉本地的module_config.json文件,重新执行命令即可,脚本会自动判断本地是否存在该配置文件,如果不存在会下载;
请确保gitlab仓库的新开发模块master分支是一个flutter模块,如果判定不是flutter模块,则会报错(判定条件为存在pubspec.yaml文件)
3.版本控制
版本控制请使用tdf_tools命令,命令详情可使用 tdf_tools -h 查看,现已支持大部分命令,若有特殊命令需要执行,可以使用 tdf_tools -c <git命令> ,如:tdf_tools -c git add .
4.自动打包发布
暂未接入打包工具,预计下一季度进行支持;
FAQ
windows系统请使用bash命令;
额外功能说明
1.二维数组表达依赖树
生成一个二维数组,可根据该二维数组的数据进行并发打tag,每一层的模块,都可以同时进行打tag发布操作,减少发布耗时;
[
["tdf_channel", "tdf_event", "tdf_network"],
["tdf_widgets"],
["tdf_smart_devices", "tdf_account_module"],
["flutter_reset_module"]
]
如上数据,数组中每一个节点中的模块均可同时打tag,节点之间需要由上至下的顺序进行tag操作
2.插件更新
执行 tdf_tools upgrade
3.远程模块配置文件更新
执行 tdf_tools module-update
依赖树分析原理
采用有向有/无环图进行依赖树的分析
数据结构采用如下:
class DependencyNode:
def __init__(self):
self.nodeName = ''
self.parent = [] # 父亲节点列表
self.children = [] # 子孙节点列表
self.delete = False
如上图1:一个正常的依赖树表示;
如上图2:对图1中,依赖树所有节点去重,变换为图2有向图;
分析流程:
依赖图构建
# 生成依赖图
def _generateDependenciesMap(self):
for package in self.__moduleDependenciesMap:
for module in moduleNameList:
if package == module:
# 到这一步表明当前这个模块属于开发模块且在当前模块的依赖模块列表中,是当前模块的子模块
self._mNodeDict[self.__moduleName].children.append(package)
self._mNodeDict[package].parent.append(self.__moduleName)
-
共5个节点
-
node构建:
-
{ "模块1":{ "nodeNmae": "模块1", "parent": [], "children": ["模块2","模块3","模块4","模块5"], "delete": False }, "模块2":{ "nodeNmae": "模块2", "parent": ["模块1"], "children": ["模块4","模块5"], "delete": False } "模块3":{ "nodeNmae": "模块3", "parent": ["模块1"], "children": ["模块5"], "delete": False } "模块4":{ "nodeNmae": "模块4", "parent": ["模块1","模块2"], "children": [], "delete": False } "模块5":{ "nodeNmae": "模块5", "parent": ["模块1","模块2","模块3"], "children": [], "delete": False } }
-
-
依赖图解析伪代码(以一维数组为例)
# 返回二维数组,用于并发打tag
def _generateDependenciesOrder(self):
resList = []
while 存在节点delete属性不为True:
for:查找子节点为0的节点
设置节点delete属性为True
for:deleteItemList = 拿到所有delete属性为true的节点
for:遍历所有节点,如果节点的子节点中包含deleteItemList的节点,则将其从子节点列表中删除
-
initial_config.json文件说明
{ "featureBranch": "feature/test_dev_1", // 开发分支 "shellName": "flutter_reset_module", // 项目需要开发的模块,可自由配置 "moduleNameList": [ "flutter_reset_module", "tdf_smart_devices", "tdf_widgets", "tdf_channel" ] }
-
module_config.json文件说明
{ "flutter_globalyun_us_module": { "id": "11111" "type": "shell", "git": "git@git.2dfire.net:app/flutter/app/flutter_globalyun_us_module.git" }, "tdf_router_anno": { "type": "base", "git": "git@git.2dfire.net:app/flutter/app/tdf_router_anno.git" }, } //语意 { "模块名":{ "id": 项目gitlab id "类型": gitlab group名 "git": gitlab地址 } }
后续计划
问题:由于现在flutter ci 【lint】【tag】任务脚本成功率过于低,很多时候是因为项目模块的配置问题导致的,且后续会接入一键打tag工具
方案:在执行统一push前,对所有模块的项目配置信息进行校验,确保数据规范;
插件打包发布命令
插件打包命令
python3 setup.py sdist bdist_wheel
插件发布命令
python3 -m twine upload --repository pypi dist/* --verbose
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file tdf_tools-1.0.31.tar.gz.
File metadata
- Download URL: tdf_tools-1.0.31.tar.gz
- Upload date:
- Size: 20.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/23.5.0 rfc3986/1.5.0 colorama/0.4.4 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cb119a5a23ed21cd099616f459cbe5d5b3f70ebb8772dfdacffb30e847d91a94
|
|
| MD5 |
dfc28b6ec4bf989dee2b6f0930ee6b84
|
|
| BLAKE2b-256 |
276231fe13237ff2aa5f7bba5438d50084483e00c4c7d60695098fb954073a3a
|
File details
Details for the file tdf_tools-1.0.31-py3-none-any.whl.
File metadata
- Download URL: tdf_tools-1.0.31-py3-none-any.whl
- Upload date:
- Size: 24.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.8.0 pkginfo/1.8.2 readme-renderer/32.0 requests/2.27.1 requests-toolbelt/0.9.1 urllib3/1.26.8 tqdm/4.62.3 importlib-metadata/4.11.1 keyring/23.5.0 rfc3986/1.5.0 colorama/0.4.4 CPython/3.8.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
399541349f24151cd1dc589923980e65ea3285c7ea3625423b5be93c595c6b78
|
|
| MD5 |
b81d10215a7ddd268b4e9051836d8936
|
|
| BLAKE2b-256 |
11130b102dbcc12be087f1a90cbe2447ad4d0290a8a50ac8fdabb46dfce0b2ec
|