Posts in Heuristics
Touring Heuristic
I seem to have a winner with my test reporting heuristic. I've used it several times now. It helps me envision and explain my test reporting. I think I will need something similar for application touring.

Here is my attempt:

FCC CUTS VIDS



The mnemonic stands for the following:

Feature tour
Complexity tour
Claims tour

Configuration tour
User tour
Testability tour
Scenario tour

Variability tour
Interopeability tour
Data tour
Structure tour


  • Feature tour: Move through the application and get familiar with all the controls and features you come across.

  • Complexity tour: Find the five most complex things about the application.

  • Claims tour: Find all the information in the product that tells you what the product does.

  • Configuration tour: Attempt to find all the ways you can change settings in the product in a way that the application retains those settings.

  • User tour: Imagine five users for the product and the information they would want from the product or the major features they would be interested in.

  • Testability tour: Find all the features you can use as testability features and/or identify tools you have available that you can use to help in your testing.

  • Scenario tour: Imagine five realistic scenarios for how the users identified in the user tour would use this product.

  • Variability tour: Look for things you can change in the application - and then you try to change them.

  • Interopeability tour: What does this application interact with?

  • Data tour: Identify the major data elements of the application.

  • Structure tour: Find everything you can about what comprises the physical product (code, interfaces, hardware, files, etc...).

Touring a new application
A couple of months ago while working with James Bach, I had a hard time getting started with an application James gave me to test. As James saw me struggling, he offered me some simple techniques for getting familiar with the application. He referred to the techniques as "tours" of the application. They are called tours because you are not necessarily looking for problems. You are simply learning the application. For a tour to become a test you would have to have an oracle (the principle or mechanism by which we recognize a problem) of some sort.



The first one he suggested was the feature tour. In the feature tour, you simply move through the application, getting familiar with all the controls and features you come across. You ask simple questions like, "What's this and what does it do?" This tour works effectively with the one factor at a time (or OFAAT) heuristic.

The second tour was the variability tour. Also related to OFAAT, you simply look for things you can change in the application - and then you try to change them. Click buttons, select values, change settings, etc... The goal is to try to get a feel for how things work and what possible values might be.

The third tour he suggested was the complexity tour. In this tour, one attempts to find the five most complex things about the application.

Looking back on those tours, I've since identified some other types of tours that I use or would like to used based on some of the other things James and I talked about:


  • Interoperability (or Compatibility) tour - With this tour you attempt to answer the question, "What the heck does this thing interact with?"

  • Claims tour - In this tour you attempt to find all the information in the product that tells you what the product does. This is helpful in checking for product consistency and claims.

  • User tour - Here you attempt to imagine five users for the product and the information they would want from the product or the major features they would be interested in.

  • Scenario tour - In this tour try to imagine five realistic scenarios for how the users identified in the user tour would use this product.

  • Structure tour - In this tour you attempt to find everything you can about what comprises the physical product (code, interfaces, hardware, files, etc...).

  • Testability tour - In this tour try to find all the features you can use as testability features and/or identify tools you have available that you can use to help in your testing.

  • Configuration tour - This tour is related to the Variability tour, but this time we are looking for persistence. Attempt to find all the ways you can change settings in the product in a way that the application retains those settings.

  • Data tour - In this tour you identify the major data elements of the application: what they are, where they are, where they go, where they come from, etc....



I'm interested in what other tours (or techniques) people use when they are getting familiar with an application.