用FauxPas找到潜在Bug

简介:

Faux Pas是一个Xcode辅助工具,检查iOS或者Mac项目,找到潜在bug,以及可维护性和风格问题。提供了92条规则可供挑选,支持GUI和CLI。目前发布了beta版,提供30天试用。

Faux Pas Homepage Faux Pas Donwload

亲身试用后,发现了项目中的多处问题。一些需要手动查找的问题,在这里都得到了检查。同时也提供了代码风格的建议和一些细节的优化建议。

功能

  • 控制潜在bug
  • 查找资源文件错误
  • 查找本地化错误
  • 发现版本控制错误
  • 学习和实施最佳实践
  • 实施代码风格
  • 代码审查清单
  • 92条规则可供挑选
  • 提供GUI或者CLI
  • 在Xcode构建时运行
  • 连接外部工具,支持导出结果和自定义脚本
  • 按标签选取规则 保存在JSON配置文件中
  • 更改打开代码的编辑器

使用方法

GUI

  • 打开FauxPas
  • 选择或者排除一些规则
  • Start Checking

CLI

  • 打开FauxPas
  • 菜单栏Faux Pas > Install CLI Tools…
  • shell> fauxpas -t iCoupon check iCoupon.xcodeproj/
  • 可以输出不同格式、挑选检查规则等,参见帮助,例如查找重复资源

  •  fauxpas --onlyRules UnusedResource -o json check MyProject.xcodeproj
    AI 代码解读


Xcode build时检查

  • 确保CLI安装
  • 在Xcode项目的target中新增"Run Script" build phase
  • 添加如下脚本,build时会执行FauxPas检查

  • [[ ${FAUXPAS_SKIP} == 1 ]] && exit 0
    
     FAUXPAS_PATH="/usr/local/bin/fauxpas"
     if [[ -f "${FAUXPAS_PATH}" ]]; then
       "${FAUXPAS_PATH}" check-xcode
     else
       echo "warning: Faux Pas was not found at '${FAUXPAS_PATH}'"
     fi
    AI 代码解读


建议不使用这种方式,会额外增加build时间。

Xcode中手动执行

  • 确保CLI安装
  • 项目中创建Aggregate类型target
  • 在该target下新增"Run Script" build phase
  • 添加如下脚本,运行该target时会执行FauxPas检查

  •  /usr/local/bin/fauxpas -o xcode check "PROJECT_NAME.xcodeproj"
    AI 代码解读


导出结果

  • GUI中点击Export Diagnostics,选择格式
  • CLI下-o参数,可选human、json、plist、xcode
  • 导出结果可以用其他工具处理

实战

使用GUI扫描了项目,发现了许多不少有价值的问题,值得我们学习。

  • 编译参数的有益建议,比如-DNDEBUG
  • 多处图片缺少和图片重复
  • 非retian与retina图尺寸不是2倍
  • 没有前缀或者前缀与SDK冲突,建议至少三字符长度
  • Retain Delegate
  • 重载或者调用一些限制的系统方法
  • 缺少获取授权的描述
  • Category方法冲突
  • 未使用的Error值,建议不关心Error时参数传入NULL
  • 设置delegate或者datasource为self时需要在dealloc中置为空
  • 对指针和0做比较
  • obj ? obj : other obj将会评估2次。而obj ?: other会评估一次
  • 界面字符串缺少本地化,我们的项目实际不需要
  • 修改传入参数的值
  • model类包含的对象的@property建议用copy,防止非setter的修改
  • pch中引用过的头文件再次引用多余
  • VCS建议,例如建议Xcode workspace data不忽略
  • 在init or dealloc不要使用setter。
  • 不和习惯的getter。使用something而非getSomething
  • 旧语法,例如+[NSNumber numberWithFloat:], -[NSDictionary objectForKey:]。建议转换为现代语法Edit → Refactor → Convert To Modern Objective-C Syntax
相关文章
修复糟糕的代码气味
修复糟糕的代码气味
81 11
【网安AIGC专题10.19】5 ChatRepair:ChatGPT+漏洞定位+补丁生成+补丁验证+APR方法+ChatRepair+不同修复场景+修复效果(韦恩图展示)
【网安AIGC专题10.19】5 ChatRepair:ChatGPT+漏洞定位+补丁生成+补丁验证+APR方法+ChatRepair+不同修复场景+修复效果(韦恩图展示)
301 0
如何快速定位现网 BUG
如何快速定位现网 BUG
125 0
缺陷(bug)管理
理论上软件的缺陷是可修复的,不过有的修复成本比较高,不能追求软件的完美,根据风险来确定是否修复缺陷
记一次bug分析定位过程
其实很多时候,我们在测试过程中发现的很多bug,并不是由于开发人员编码能力不好,或者粗心大意造成,而是在项目开发实施过程中,没有遵循一些必要的项目流程,没有充分认识到质量的重要性;如果能做好这方面的工作,关注流程,而不是喊口号,人人重视质量,人人为结果负责,那么,会有很多问题、不只是bug,都将“被扼杀在摇篮里”......
记一次bug分析定位过程
编程基本功:找到问题的合理解释,才算解决问题
编程基本功:找到问题的合理解释,才算解决问题
105 0
找到根因,才能从根本上解决问题
源自我参与的一个项目在用户那里出了bug,当然非我的改动引发,是之前处理数据未考虑到异常。
2330 0
Web测试中定位bug方法
在web测试过程中,经常会遇到页面中内容或数据显示错误,甚至不显示,第一反应就是BUG,进一步了解这个BUG的问题出在那里,是测试人员需要掌握的,可以简单的使用浏览器自带开发者工具、数据库工具配合去排查。
1909 0
有时候,解决问题比写代码更重要!
当你手里有把锤子的时候,看所有的东西都是钉子。 有时候程序员往往会陷入为了写代码而写代码的怪圈,没有意识到代码是为了解决现实问题的。当问题有更简便的解决方案时,写代码未必就是必须。
923 0