Replace test plan with ACC

2012-03-14  刘旸 

去年10月参加STARWEST的时候就听到ACC的概念,但是因为自己的E文实在是有点差劲,听的一直云里雾里,

现在终于发现ACC的具体解释,还是比较清楚的。分享给大家看一下,是不是真的可以取代test plan

Introduction

Test Analytics allows you to efficiently construct an ACC model for your project. This ACC model, shorthand for Attributes-Components-Capabilities, will in many ways replace a conventional test plan. It's faster to write, can direct you toward missing coverage, and is the framework for calculating a risk surface map for your project.

For a moderately sized project, an initial ACC breakdown might take 20 minutes to an hour. In this time, you'll define the three parts of the ACC model for your project: Attributes, Components, and Capabilities.

Why ACC?

Many test plans suffer from one or more common problems:

  • Difficult to keep up-to-date and become obsolete
  • Written ad-hoc, leading to holes in coverage
  • Ignored after initial creation or review
  • Give little actionable data
  • Disorganized, difficult to consume all related information at once

In addition, we've found that when trying to utilize risk-based testing methodologies, a conventional test plan doesn't give a good visual map of the project -- there's no great place to start or end when determining risk, nor do they provide a good mechanism by which to visualize the risk.

ACC aims to solve that in a simple way. It's an easy-to-follow process that can be applied consistently to projects quickly. At the end of the process, you have a system of coherent and logically-related elements, in a form which is easy to digest.

What is ACC?

ACC consists of three different parts that define your system under test: Attributes, Components, and Capabilities. An easy way to think of each of these elements is by relating them to a part of speech relating to your project.

  • Attributes (adjectives of the system) are qualities and characteristics that promote the product and distinguish it from the competition; examples are "Fast", "Secure", "Stable", and "Elegant". A product manager could have a hand in narrowing down the list of Attributes for the system.
  • Components (nouns of the system) are building blocks that together constitute the system in question. Some examples of Components are "Firmware", "Printing", and "File System" for an operating system project, or "Database", "Cart", and "Product Browser" for an online shopping site.
  • Capabilities (verbs of the system) describe the abilities of a particular Component in order to satisfy the Attributes of the system. An example Capability for a shopping site could be "Processes monetary transactions using HTTPS". You can see that this could be a Capability of the "Cart" component when trying to meet the "Secure" Attribute. The most important aspect of Capabilities is that they are testable.

Defining Capabilities requires you to visit each intersection point between Attributes and Components; this often can lead to discovery of areas which otherwise may have gone unrecognized or untested in a conventional test plan. This could be as simple as assuring there is thought put into the security of an entire system (via the Attribute "Secure"), or details specific to your project when considered to specific characteristics you want your product to exhibit. It can also help assure consideration is given to all qualities are considered as new Capabilities are added to your product.

How?

Constructing an ACC model is designed to be a simple, methodical process that can be executed quickly. No special tools are required to construct an ACC model -- you could draft one on paper, or a whiteboard -- but Test Analytics was specifically designed to make construction a breeze. In addition, it has a few built-in visualizations that add value to the model you make.

Define Your Attributes

The first step is to figure out your product's Attributes. To start, think about the qualities of your product that are critical to its success. You can also consider what differentiates your product from any competitors. Attributes are big-picture items; don't worry if they seem vague at first.

Here are some common items we've noticed have appeared in several projects, which might spark some ideas:

  • Secure
  • Fast
  • Powerful
  • Stable
  • Personal
  • Social

You can define these on the Attribute page of Test Analytics.

Define Your Components

The Components of your project are the big pieces of your application. They might echo how a developer on your product would split the project apart. In an e-commerce website these could be things like "Shopping Cart" or "Account Page".

Since the Components of projects can vary a lot depending on the type of project it is, there's not a list of "typical" parts. Here are a few that may help you think how to divide your project:

  • Database
  • API
  • Search
  • Sharing
  • Login
  • Shopping Cart

You enter these, similar to Attributes, but on the Components page of your Test Analytics project.

Define Your Capabilities

Now comes the fun part! Capabilities are the things your project does. To compare to a test plan, a Capability might cover a group of related tests all in one succinct sentence.

A Capability is tied to one specific parent Attribute and Component -- a Capability will be what your product needs to do to make sure a Component fulfills the Attribute. To use some of the previous examples, you would define capabilities under pairs like "Database is Secure" or "Search is Fast".

Each Attribute and Component pair could have several Capabilities associated with it, or possibly none if that combination doesn't make sense. Login is Social may not have any Capabilities associated with it whereas API is Powerful might have several.

Here's some examples of Capabilities:

  • Database is Secure: "All credit card information is stored encrypted", "Passwords are not stored plain-text"
  • Search is Fast: "All search queries return in less than 1 second"

To define your Capabilities, Test Analytics presents you with a grid of your Attributes versus Components. You can select a cell which represents an Attribute and Component pair. After selecting, you can then start defining Capabilities for that pair.

This is where value of ACC can shine: by showing a grid pairing what qualities of your application are important against the parts of your application, it can yield tests you may not previously have considered.

The Capabilities themselves should not be test cases themselves: they're intended to be higher level. They can serve as a good starting point for a manual testing tour, or as a classification under which you can define test cases.

Once you've defined your Capabilities, you're ready to start using the risk assessment portions of Test Analytics to start visualizing the parts of your application that need attention.

465°/4615 人阅读/4 条评论 发表评论

熊志男  2012-03-14

“听的一直云里雾里” me too,hehe.
下面是我蹩脚的翻译:
特性(安全、快捷、稳定)和 组件(数据库、购物车、产品浏览器),
组合成Capabilities 能力(通过HTTPS货币交易),覆盖了“安全”特性和“购物车”组件。

需要好好学习学习英语,研究研究ACC,挺有意思的。


刘旸  2012-03-15

熊志男: “听的一直云里雾里” me too,hehe.
下面是我蹩脚的翻译:
特性(安全、快捷、稳定)和 组件(数据库、购物车、产品浏览器),
组合成Capabilities 能力(通过HTTPS货币交易),覆
应该差不多就是这个意思。


刘旸  2012-03-15

对了,https://test-analytics.appspot.com/ 是google open source的一个辅助使用ACC的在线系统。当然也可以下载source code自行安装。 不过这个网站需要翻墙。


张林  2012-03-16

Here,
http://code.google.com/p/test-analytics/

没用过,不知道结合实际有多大价值?


登录 后发表评论