测试建模:Google ACC

发表于:2012-07-09来源:博客园作者:liangshi点击数: 标签:软件测试建模
ACC(Attributes Components Compatibilities)是Google测试团队使用的一种建模方法,用来快速地建立产品的模型,以指导下一步的测试计划和设计。在Google内部,ACC得到较普遍的应用,一些工程师还开发了支持ACC模型的Web应用,并将其开源。本文将介绍ACC的内容

  ACC(Attributes Components Compatibilities)是Google测试团队使用的一种建模方法,用来快速地建立产品的模型,以指导下一步的测试计划和设计。在Google内部,ACC得到较普遍的应用,一些工程师开发了支持ACC模型的Web应用,并将其开源。本文将介绍ACC的内容,所引用的Google+的例子摘录自《How Google Tests Software》一书。此外,本文还将使用启发式测试策略模型(Heuristic Test Strategy Model,简称HTSM)来分析ACC。

  运用ACC建模的第一步是确定产品的Attributes(属性)。按照谷歌的定义,Attributes是产品的形容词(adjectives),是与竞争对手相区别的关键特征。按照敏捷开发的观点,Attributes是产品所交付的核心价值(values)。从HTSM的角度,Attributes位于HTSM->Quality Criteria->Operation Criteria,隶属于面向用户的质量标准。

  Google+的Attributes如下:

  Social(社交):鼓励用户去分享信息和他们的状态

  Expressive(表现力):用户可以运用各种功能去表达自我

  Easy(容易):让用户以直观的方式做他们想做的事

  Relevant(相关):只显示用户感兴趣的内容

  Extensible(可扩展):能够与Google的已有功能、第三方网站和应用(Application)集成

  Private(隐私):用户数据不会泄漏

  ACC以Attribute开始,是产品竞争的自然选择,也符合Google的开发实践。在Google的项目中,开发人员和测试人员的比例通常是10:1或更高。开发人员会编写大量的自动化测试用例,对产品实施周密的测试,因此测试人员主要关注用户价值和系统级测试。即便如此,测试人员也没有足够的资源测试所有用户行为。所以,测试人员需要通过确定Attributes来明确产品的核心价值,从而区分出测试对象的轻重缓急(priorities)。获取Attributes的信息源可以是产品经理、市场营销人员、技术布道者、商业宣传材料、产品广告等。测试人员也可以使用“卖点漫游”(The Money Tour)来发掘和检验产品的卖点。

  第二步是确定产品的Components(部件)。Components是产品的名词(nouns),可以理解为产品的主要模块、组件、子系统。从HTSM的角度,Components位于HTSM->Product Elements->Structure和HTSM->Product Elements->Function,即同时具备代码结构和产品功能的特征。

  Google+的Components如下:

  Profile(个人资料):用户的帐户信息和兴趣爱好

  People(人脉):用户已经连接的好友

  Stream(信息流):由帖子、评论、通知、照片等组成的有序的信息流

  Circles(圈子):将好友分组,如把不同的好友归于“朋友”、“同事”等小组

  Notifications(通知):当用户被帖子提到时,向他显示提示信息

  Hangouts(视频群聊):视频对话的小组

  Posts(帖子):用户和好友所发表的信息

  Comments(评论):对帖子、照片、视频等的评论

  Photos(照片):用户和好友所上传的照片

  Components可以看作功能列表(Function List)的顶层元素,是产品核心功能的清单。《How Google Tests Software》建议Components列表要尽可能简单,10个Components很好,20个就太多了。其目的是重点考虑对产品、对用户最重要的功能与代码,并避免漫长的Components列表所导致的分析瘫痪。

  第三步是确定产品的Capabilities(能力)。Capabilities是产品的动词(verbs),描述了一个Component提供了何种能力来实现一个Attribute。在HTSM的角度,Capabilities位于HTSM->Product Elements->Function和HTSM->Quality Criteria->Operation Criteria->Capability,刻画了产品实现其核心价值的手段。

  Google+的Capabilities矩阵如下:

 

Social

Expressive

Easy

Relevant

Extensible

Private

Profile

在好友中分享个人资料和兴趣爱好

用户可以在网上表达自我

很容易创建、更新、传播信息

 

向被批准的、拥有恰当访问权限的应用提供数据

    • 用户可以保密隐私信息
    • 只向被批准、拥有恰当访问权限的应用提供信息

People

用户能够连接他的朋友

用户可以定制个人资料,使自己与众不同

提供工具让管理好友变得轻松

用户可以用相关性规则过滤好友

向应用提供好友数据

只向被批准、拥有恰当访问权限的应用提供信息

Stream

向用户提示其好友的更新

 

 

用户可以根据兴趣过滤好友更新

向应用提供信息流

 

Circles

将好友分组

根据用户的语境创建新圈子

鼓励创建和修改圈子

 

向应用提供圈子数据

 

Notifications

 

 

简明地展示通知

 

向应用提供通知数据

 

Hangouts

    • 用户可以邀请他们的圈子加入群聊
    • 用户可以公开其群聊
    • 好友访问用户的信息流时,他们被告知群聊

加入群聊前,用户可以预览自己的形象

 

    • 只要几次点击就可以创建并加入群聊
    • 只要一次点击就可以关闭视频和音频输入
    • 可将好友加入已有的群聊

 

    • 用户可以在群聊中使用文字交流
    • YouTube视频可以加入群聊
    • 在“设置”中可以配置群聊的硬件
    • 没有摄像头的用户可以音频交谈
    • 只有被邀请的用户才能加入群聊
    • 只有被邀请的用户才能收到群聊通知

Posts

 

表达用户的想法

 

 

向应用提供帖子数据

帖子只向被批准的用户公布

Comments

 

用评论表达用户的想法

 

 

向应用提供评论数据

评论只向被批准的用户公布

Photos

用户可以分享他的照片

 

    • 用户能方便地上传照片
    • 用户能方便的从其他来源导入照片

 

与其他照片服务集成

照片只向被批准的用户公布

原文转自:http://www.ltesting.net