互联网敏捷项目质量保障体系方案

本文是我在当前项目上设计的质量保障方案,在进行项目信息脱敏后,总结如下。


质量 = 正常工作的软件 + 满足项目干系人的需求


主动性质量管理 --> 预防 + 评审

流程

  1. 开发流程
    1.1 每一个环节明确的进入退出条件
    1.2 多轮质量反馈机制
    - 开发团队日常的反馈
    - 站会
    - IPM
    - 开卡&结卡
    - 客户/用户的反馈 + showcase
  2. 持续集成/持续部署流程
    2.1 加入代码扫描,自动化测试等
    2.2 失败处理
  3. 与上下游方的沟通联调流程

需求

  1. 需求分析和澄清
  2. 需求符合INVEST原则,无二义性和歧义性
  3. PO积极性,能够及时响应和回答
  4. AC的定义,完工的定义,测试结束的定义

开发实践

  1. Code Review 代码审查
  2. Peer Review (via PR) 同行评审
  3. TDD
  4. Pairing 结对编程

代码质量

  1. 静态测试

1.1 统一的编码规范:比如命名规则,注释,代码格式,函数复杂度等

  • 可以结合业界标准。比如Sun Code Convent和Google Style等
  • 使用工具扫描代码。比如JS的ESlint
  • 可以在IDE装相关插件,做到编码时检测

1.2 静态代码扫描

  • 集成到CI流水线中。SonarQube
  • IDE插件,做到编码时检测
  1. 动态测试

2.1 前端单元测试
2.2 后端单元测试

风险管理

  1. 可视化风险
  2. 及时暴露和管理风险

项目实践

  1. 定期Retro
  2. 知识管理
  3. API文档管理
  4. 新人培训
  5. 追求技术卓越
  6. 面对面沟通
  7. 集中办公

被动型质量管理 --> 测试 + 检验

质量属性

  1. 功能性
    • 完成度
    • 精准度
    • 互用性
    • 效率
    • 并发
  2. 性能
    • 资源利用率
    • 吞吐量
    • 持久力
  3. 安全
    • 认证
    • 授权
    • 隐私
  4. 兼容性
    • 应用兼容
    • OS兼容
    • 硬件兼容
    • 向后兼容
  5. 可用性
    • 易学性
    • 易操作性
    • 可达性
  6. 可靠性
    • 稳定性
    • 健壮性
    • 可恢复性
    • 错误处理
    • 数据完整性
  7. 可维护性
    • 可扩展性
    • 修复
    • 构建
  8. 可移植性
    • 重用
  9. 可安装性
    • 配置
    • 升级卸载

测试活动

质量属性 测试类型
功能性 功能测试、集成测试、探索式测试、用户验收测试、流测试、回归测试
性能 压力测试、负载测试
安全 渗透测试、威胁建模
兼容性 兼容性测试
可用性 用户测试、Alpha测试、Beta测试
可靠性 风险测试、场景测试、域测试(domain testing)、流测试、压力测试
可维护性 单元测试
可移植性 专项测试
可安装性 专项测试

测试策略

SDLC 测试类型 方法 框架/工具 策略
Code 单元测试 自动化 Junit, pytest, mocha, jasmine 采用TDD,覆盖率检查,QA review UT,每次构建在CI执行
Test 冒烟测试 手工/自动化 webdriver 针对每次build在CI执行地自动化冒烟测试,在shoulder check环节的冒烟测试,与Build Verification Testing类似,每次build都要通过的测试
Test 功能测试 (系统测试) 手工/自动化 webdriver 故事卡测试 - 探索式测试,故事卡测试 - 场景验收测试,自动化UI测试,自动化API测试,自动化测试在CI流水线执行,自动化测试也可以单独在CI执行
Test 集成测试 自动化 Rest assured,pact 覆盖依赖服务的测试,可以使用mock
Test 性能测试 自动化 locust,gatling 压力测试,负载测试
Test 兼容性测试 手工/自动化 Browserstack 确定产品支持的主流平台和浏览器
Test 安全测试 自动化 HP Fortify 渗透测试
Test 回归测试 手工/自动化 故事卡缺陷的回归测试,AC的回归测试,相关代码配置改动引起的回归测试,缺陷卡回归测试,上线前的回归测试 - Candidate testing, PVT
UAT 用户验收测试 手工 每个故事卡QA测试结束后,需要客户进行在UAT环境进行测试。只有当UAT通过了,才表明这个故事卡done,QA需要在此环节和business进行协调

质量度量

  • 缺陷统计度量
    • 解决率
    • 解决时间
    • 分布
    • 触发原因
    • 严重性
    • 优先级
    • 数量变化趋势
  • 覆盖率
    • 需求覆盖率
    • 故事卡AC覆盖率
    • 代码覆盖率
      • 函数覆盖数量
      • 运行使用到的功能覆盖数量
      • 条件覆盖数量
      • path覆盖数量
    • 自动化测试覆盖率
      • 运行通过的测试比率
        • 功能稳定程度
      • 不同开发阶段的比率
  • 兼容
    • 支持哪些浏览器
    • 移动端支持多分辨率机型
  • 代码质量
    • 静态代码扫描问题数
  • 技术负载率
    • 剩余技术负债点数
  • 用户/客户反馈
    • 线上问题反馈
    • 满意度反馈
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,377评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,390评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,967评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,344评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,441评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,492评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,497评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,274评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,732评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,008评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,184评论 1 342
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,837评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,520评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,156评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,407评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,056评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,074评论 2 352