I like the Anderson / Krathwohl approach (simple summaries here and here and here). One of the key improvements in this update to Bloom’s taxonomy was the inclusion of different types of knowledge (The Knowledge Dimension) as well as different levels of knowledge (The Cognitive Process Dimension).
The Knowledge Dimension | The Cognitive Process Dimension | |||||
---|---|---|---|---|---|---|
Remember | Understand | Apply | Analyze | Evaluate | Create | |
Factual knowledge
|
||||||
Conceptual knowledge
|
||||||
Procedural knowledge
|
||||||
Metacognitive knowledge
|
||||||
Original Anderson Krathwohl model
|
This is a useful model, but there are things we learn as software testers that don’t quite fit in the knowledge categories. After several discussions with James Bach, I’ve adopted the following revision as the working model that I use:
The Knowledge Dimension | The Cognitive Process Dimension | |||||
---|---|---|---|---|---|---|
Remember | Understand | Apply | Analyze | Evaluate | Create | |
Facts
|
||||||
Concepts
|
||||||
Procedures
|
||||||
Cognitive strategies
|
||||||
Models
|
||||||
Skills
|
||||||
Attitudes
|
||||||
Metacognition
|
||||||
Anderson Krathwohl model modified for software testing
|
Here are my working definitions / descriptions:
Facts
- A “statement of fact” is a statement that can be unambiguously proved true or false. For example, “James Bach was born in 1623” is a statement of fact. (But not true, for the James Bach we know and love.) A fact is the subject of a true statement of fact.
- Facts include such things as:
- Tidbits about famous people
- Famous examples (the example might also be relevant to a concept, procedure, skill or attitude)
- Items of knowledge about devices (for example, a description of an interoperability problem between two devices
Concepts
- A concept is a general idea. “Concepts are abstract in that they omit the differences of things in their extension, treating them as if they were identical.” (wikipedia: Concept).
- In practical terms, we treat the following kinds of things as “concepts” in this taxonomy:
- definitions
- descriptions of relationships between things
- descriptions of contrasts between things
- description of the idea underlying a practice, process, task, heuristic (whatever)
- Here’s a distinction that you might find useful.
- Consider the oracle heuristic, “Compare the behavior of this program with a respected competitor and report a bug if this program’s behavior seems inconsistent with and possibly worse than the competitor’s.”
- If I am merely describing the heuristic, I am giving you a concept.
- If I tell you to make a decision based on this heuristic, I am giving you a rule.
- Sometimes, a rule is a concept.
- A rule is an imperative (“Stop at a red light”) or a causal relationship (“Two plus two yields four”) or a statement of a norm (“Don’t wear undershorts outside of your pants at formal meetings”).
- The description / definition of the rule is the concept
- Applying the rule in a straightforward way is application of a concept
- The decision to puzzle through the value or applicability of a rule is in the realm of cognitive strategies.
- The description of a rule in a formalized way is probably a model.
- Consider the oracle heuristic, “Compare the behavior of this program with a respected competitor and report a bug if this program’s behavior seems inconsistent with and possibly worse than the competitor’s.”
Procedures
- “Procedures” are algorithms. They include a reproducible set of steps for achieving a goal.
- Consider the task of reporting a bug. Imagine that someone has
- broken this task down into subtasks (simplify the steps, look for more general conditions, write a short descriptive summary, etc.) and
- presented the tasks in a sequential order.
- This description is intended as a procedure if the author expects you to do all of the steps in exactly this order every time.
- This description is a cognitive strategy if it is meant to provide a set of ideas to help you think through what you have to do for a given bug, with the understanding that you may do different things in different orders each time, but find this a useful reference point as you go.
Cognitive Strategies
- “Cognitive strategies are guiding procedures that students can use to help them complete less-structured tasks such as those in reading comprehension and writing. The concept of cognitive strategies and the research on cognitive strategies represent the third important advance in instruction.
“There are some academic tasks that are “well-structured.” These tasks can be broken down into a fixed sequence of subtasks and steps that consistently lead to the same goal. The steps are concrete and visible. There is a specific, predictable algor ithm that can be followed, one that enables students to obtain the same result each time they perform the algorithmic operations. These well-structured tasks are taught by teaching each step of the algorithm to students. The results of the research on tea cher effects are particularly relevant in helping us learn how teach students algorithms they can use to complete well-structured tasks.
“In contrast, reading comprehension, writing, and study skills are examples of less- structured tasks — tasks that cannot be broken down into a fixed sequence of subtasks and steps that consistently and unfailingly lead to the goal. Because these ta sks are less-structured and difficult, they have also been called higher-level tasks. These types of tasks do not have the fixed sequence that is part of well-structured tasks. One cannot develop algorithms that students can use to complete these tasks.”
Gleefully pilfered from: Barak Rosenshine, Advances in Research on Instruction, Chapter 10 in J.W. Lloyd, E.J. Kameanui, and D. Chard (Eds.) (1997) Issues in educating students with disabilities. Mahwah, N.J.: Lawrence Erlbaum: Pp. 197-221. - In cognitive strategies, we include:
- heuristics (fallible but useful decision rules)
- guidelines (fallible but common descriptions of how to do things)
- good (rather than “best” practices)
- heuristics (fallible but useful decision rules)
- The relationship between cognitive strategies and models:
- deciding to apply a model and figuring out how to apply a model involve cognitive strategies
- deciding to create a model and figuring out how to create models to represent or simplify a problem involve cognitive strategies
BUT
- the model itself is a simplified representation of something, done to give you insight into the thing you are modeling.
- We aren’t sure that the distinction between models and the use of them is worthwhile, but it seems natural to us so we’re making it.
Models
- A model is
- A simplified representation created to make something easier to understand, manipulate or predict some aspects of the modeled object or system.
- Expression of something we don’t understand in terms of something we (think we) understand.
- A state-machine representation of a program is a model.
- Deciding to use a state-machine representation of a program as a vehicle for generating tests is a cognitive strategy.
- Slavishly following someone’s step-by-step catalog of best practices for generating a state- machine model of a program in order to derive scripted test cases for some fool to follow is a procedure.
- This definition of a model is a concept.
- The assertion that Harry Robinson publishes papers on software testing and models is a statement of fact.
- Sometimes, a rule is a model.
- A rule is an imperative (“Stop at a red light”) or a causal relationship (“Two plus two yields four”) or a statement of a norm (“Don’t wear undershorts outside of your pants at formal meetings”).
- A description / definition of the rule is probably a concept
- A symbolic or generalized description of a rule is probably a model.
Skills
- Skills are things that improve with practice.
- Effective bug report writing is a skill, and includes several other skills.
- Taking a visible failure and varying your test conditions until you find a simpler set of conditions that yields the same failure is skilled work. You get better at this type of thing over time.
- Entries into this section will often be triggered by examples (in instructional materials) that demonstrate skilled work, like “Here’s how I use this technique” or “Here’s how I found that bug.”
- The “here’s how” might be classed as a:
- procedure
- cognitive strategy, or
- skill
- In many cases, it would be accurate and useful to class it as both a skill and a cognitive strategy.
Attitudes
- “An attitude is a persisting state that modifies an individual’s choices of action.” Robert M. Gagne, Leslie J. Briggs & Walter W. Wager (1992) “Principles of Instructional Design” (4th Ed),, p. 48.
- Attitudes are often based on beliefs (a belief is a proposition that is held as true whether it has been verified true or not).Instructional materials often attempt to influence the student’s attitudes.
- For example, when we teach students that complete testing is impossible, we might spin the information in different ways to influence student attitudes toward their work:
- given the impossibility, testers must be creative and must actively consider what they can do at each moment that will yield the highest informational return for their project
- given the impossibility, testers must conform to the carefully agreed procedures because these reflect agreements reached among the key stakeholders rather than diverting their time to the infinity of interesting alternatives
- Attitudes are extremely controversial in our field and refusal to acknowledge legitimate differences (or even the existence of differences) has been the source of a great deal of ill will.
- In general, if we identify an attitude or an attitude-related belief as something to include as an assessable item, we should expect to create questions that:
- define the item without requiring the examinee to agree that it is true or valid
- contrast it with a widely accepted alternative, without requiring the examinee to agree that it is better or preferable to the alternative
- adopt it as the One True View, but with discussion notes that reference the controversy about this belief or attitude and make clear that this item will be accepted for some exams and bounced out of others.
Metacognition
- Metacognition refers to the executive process that is involved in such tasks as:
- planning (such as choosing which procedure or cognitive strategy to adopt for a specific task)
- estimating how long it will take (or at least, deciding to estimate and figuring out what skill / procedure / slave-labor to apply to obtain that information)
- monitoring how well you are applying the procedure or strategy
- remembering a definition or realizing that you don’t remember it and rooting through Google for an adequate substitute
- Much of context-driven testing involves metacognitive questions:
- which test technique would be most useful for exposing what information that would be of what interest to who?
- what areas are most critical to test next, in the face of this information about risks, stakeholder priorities, available skills, available resources?
- Questions / issues that should get you thinking about metacognition are:
- How to think about …
- How to learn about …
- How to talk about …
- In the BBST course, the section on specification analysis includes a long metacognitive digression into active reading and strategies for getting good information value from the specification fragments you encounter, search for, or create.