提交代码自动为标签添加 唯一ID 属性
使用原理:git commit 时使用 pre-commit 勾子对已经 git add 的文件里对所有 tag 添加唯一ID属性
解决疼点:UI 自动化测试时,页面上标签的标识变更导致UI测试用例需要重写, feuid 主要为了减少ID变更造成的影响
* 使用 git 管理的项目
* 使用 npm package.json 安装依赖的前端项目
* 使用 vue 框架的前端项目
sudo npm install -g feuid && feuid --auto
sudo npm install -g feuid
cd projectRoot && feuid --auto
# feuid --auto = feuid --setup && feuid --full
cd projectRoot && feuid --setup
# 这个指令自动添加2个npm模块 feuid、pre-commit
# 并在 package.json 的 scripts 添加 feuid 指令
# 和在 package.json 添加 pre-commit: ["feuid"] 设置
# 拷贝 feuid 模块里的 feuid.config.js 到项目根目录
cd projectRoot && feuid --full
# 处理所有符合条件的文件
cd projectRoot && feuid --target ./filepath.vue
# 处理单个指定的文件
feuid --full --update
# 通常与 --full 或者 --target 结合使用
feuid --help
# 显示所有可用命令
如果运行命令的项目根目录有 feuid.config.js,工具会自动读取配置参数
{
"extension": [ 'vue' ] //需要处理的文件后缀名
, "language": "vue" //处理标签的前端框架,目前只支持 vue, 未来会支持 react、angular
, "repository": "git" //代码存储的仓库类型,目前只支持 git, 未来会添加 svn 支持
, "dir": [ 'src' ] //需要处理唯一ID的目录,默认为 src
, "encoding": "utf8" //项目中的文件编码
, "attrname": "data-testid" //唯一ID的属性名
, "countattrname": "data-feuidindex"//列表循环的标签计数索引值
, "idprefix": "fe" //唯一ID属性值的前缀名
, "fixempty": true //如果唯一ID属性为空自动修复
, "fixrepeat": true //如果唯一ID重复自动去重
//忽略处理的标签名
, "ignoretag": [ "v-hover", "template", "el-table-column" ]
}