Skip to main content

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中


        封包工具相关
        ------------------------------------------------------------------------
        map                     以二维数组形式输出模块的依赖顺序每一item列表代表可同时打tag的模块
        tagInfo                 输出一个json每一节点包含一个模块内部包含
                                remote远程最新版本号current模块内配置的版本号upgrade对比自增后的版本号sort模块打tag顺序
                                sort相同即代表可同时打tag
        prepareTagTask          修改yaml中的tag号和所有的依赖该命令可看成是做打tag前的准备工作把依赖规范化
        tag                     批量tag操作参数通过逗号隔开不要有空格如tdf_tools tag tdf_widgets,tdf_event


        路由相关
        ------------------------------------------------------------------------
        router                  执行tdf_tools router后会以交互式进行路由操作对指定的模块执行路由生成和路由注册逻辑


        国际化相关
        ------------------------------------------------------------------------
        translate                  执行tdf_tools translate后会以交互式进行路由操作对指定的模块执行国际化代码生成


        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.准备工作

  • 确保python的bin插件目录已经被配置到环境变量中(这一步不满足的话,插件安装之后是无法识别到本插件命令的)

  • 在~目录下,创建.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

dependency

如上图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
              
            fordeleteItemList = 拿到所有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

History

1.0.55(2022-4-28)

  • 国际化key使用中文(依照ios项目开发形式);

1.0.53(2022-4-28)

  • 国际化流程中,兼容解决部分json解析失败问题,譬如字符串中包含"="符号;

错误日志如:Unterminated string starting at: line 1 column 5650 (char 5649)

1.0.50(2022-4-28)

  • 国际化增加繁体字翻译;

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

tdf_tools-1.0.55.tar.gz (31.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tdf_tools-1.0.55-py3-none-any.whl (34.8 kB view details)

Uploaded Python 3

File details

Details for the file tdf_tools-1.0.55.tar.gz.

File metadata

  • Download URL: tdf_tools-1.0.55.tar.gz
  • Upload date:
  • Size: 31.1 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.9

File hashes

Hashes for tdf_tools-1.0.55.tar.gz
Algorithm Hash digest
SHA256 d6ffbebd57d2b0814f693637cc7e398fcd8a54c61941f19cedc0517c25ced6d6
MD5 e85b262a4550fcd06c5d304cf5182454
BLAKE2b-256 9776c29f800919b7f17d0890cdb4c5336a12dd2ab423af92aeecc7ba0d776e85

See more details on using hashes here.

File details

Details for the file tdf_tools-1.0.55-py3-none-any.whl.

File metadata

  • Download URL: tdf_tools-1.0.55-py3-none-any.whl
  • Upload date:
  • Size: 34.8 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.9

File hashes

Hashes for tdf_tools-1.0.55-py3-none-any.whl
Algorithm Hash digest
SHA256 4b9f6ff43a0304c8a0b9f3744e52b5c7fe9de40614a724db148af549c0b1b1b5
MD5 8e043f15317e2492a8a5d98b2d800efd
BLAKE2b-256 399d8c830b2f4aca745e8534fa84abb7c6d9a1b4be3a3880a42f51c8560120ba

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page