<span class="image"> <img src="req42-logo.png" alt="req42"> </span> Template

About req42

req42, the framework for collecting, documenting and communicating requirements.

Created and maintained by Dr. Peter Hruschka, Markus Meuten and contributors.

Template Revision: 2.0 EN (based on asciidoc), March 2023

© We acknowledge that this document uses material from the req42 framework, https://req42.de

*

Hinweis

This version of the framework contains help texts and explanations. It is meant to familiarize yourself with the framework. For your own documentation better use the plain Version.

1. Business Goals

Content

The business objectives of your product development or project. Short and concise, understandable and transparent for your stakeholders.

Motivation

Goals must be specified and agreed upon to the point where everyone involved has a clear idea of what is to be accomplished and in what time frames. Establishing vision and goals guides the team in developing detailed requirements and avoids fragmentation.

Perhaps your clients gave you rough goals or a vision when they entrusted you with the role of product owner. Often, however, the precision of these specifications is not enough to lead a team systematically to success.

Notations/Tools

A wide variety of means of expression are available for defining goals, which you can choose according to your mood.

Our recommendation:

  • Notation in the form of PAM (Purpose, Advantage, Metric).

Alternative forms of notation:

  • Product case

  • News from the Future

  • Product Canvas

  • Value Proposition

There is only one thing you should never do: Work without explicit goals or visions.

Goal definitions according to PAM:

Goal 1:

Advantage 1:

Metric 1:

Goal 2:

Advantage 2:

Metric 2:

Goal 3:

Advantage 3:

Metric 3:

2. Stakeholder

Content

A (prioritized) list of your stakeholders, along with indications of where these stakeholders can help (or hinder) the analysis work.

Motivation

Stakeholders are the most important sources for requirements. Therefore, you should know and document them. You need to know who can help you with what or hinder you in what way. You need to know who has what influence - and if opinions differ, you need to mediate or decide. Without explicitly identified stakeholders, all this is difficult.

Notations/Tools
  • Tables or lists (simple form)

  • Possibly stakeholder map (more complex form)

Below we have included a simple stakeholder list as an example.

The order "role before person" has been chosen deliberately. This order has proven itself since requirements normally always represent needs from the perspective of a role, but the person taking on the role can change during the project.

If required, you can also add further columns (contact data, …) - but consider the effort for their maintenance.

Role

Person

Topic

Influence

<Role-1>

<Person-1>

<Topic-1>

_<Influence-1>

<Role-2>

<Person-2>

<Topic-2>

_<Influence-2>

3. Scope

Content

Your product with all external interfaces to (human and automated) neighbors, resp. neighboring systems.

Motivation

Scope is the area that you can influence. The environment of the product, to which there are certainly many interfaces, represents the context. The context cannot (usually) be decided by you alone, but can often be negotiated. To gain clarity it is important to describe both as much as possible and especially to define the boundary between the two scopes.

req42 recommends that you start with the business scope and do not limit the product scope too early. The decision about the product scope should be a conscious one. Read more about this indispensable topic in the blog post "Scope is not equal to Scope" or in [2]. In our courses, you will practice scope delimitation using a realistic case study.

Notations/Tools

There are many different means of expression for representing scope delineation, but a good scope delineation makes the interfaces to the context explicit (e.g., in terms of inputs and outputs, of services provided and required, …).

  • Various forms of context diagrams

  • Context chart

Optional: add table with explanations of interfaces:

Interface Name

Meaning/Explanation

<IF-1>

<Meaning-1>

<IF-2>

<Meaning-2>

4. Product Backlog

Content

An ordered list of product backlog items (at different levels of granularity: e.g. epics, features and user stories). Backlog items should be prioritized (better term: ranked) among each other.

The items with the greatest added value in terms of implementation effort should be at the top of the backlog to be implemented next.

You have to define explicitly what added value means for you and your development. The simplest definition is the business added value for the customer when implementing the requirement.

Motivation

The Scrum Guide defines:

"The Product Backlog is an ordered list of everything that is known to be included in the product. It serves as the single source of requirements for all changes to the product. The Product Owner is responsible for the Product Backlog, its contents, access to it, and the order of entries. A Product Backlog is never complete. During its initial development steps, it identifies the requirements that are initially known and best understood. The Product Backlog evolves with the product and its use. It is dynamic; it constantly adapts to make clear for the product what it needs to be adequate to its task, to compete, and to provide the required benefits."

As long as a product exists, so does its Product Backlog. So you see: the Product Backlog is really important for successful work as a Product Owner. But please fill in the other artifacts as well. Your job may not start with the Product Backlog and it certainly doesn’t end with the Product Backlog.

Notations/Tools

Proven (regardless of granularity) for epics, features and user stories is the formula:

As <role> I want <functionality> so that <advantage>.

For the more abstract levels (epics, features), compound nouns may also be suitable for describing functionality.

Use ALM tools or ticket systems (JIRA or Azure DevOps) or wikis (like Confluence) to manage your epics, features and stories (linked and ordered).

A two-dimensional representation of the product backlog in the form of a story map has proven particularly useful.

EPIC 1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

FEATURE 1.1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 1.1.1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 1.1.x.:As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

EPIC 2: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

FEATURE 2.1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 2.1.1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 2.1.2: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

FEATURE 2.2: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 2.2.1: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

STORY 2.2.2: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

EPIC 3: As <role> I want <functionality> so that <advantage>. <optional: Link to models>.

5. Supporting Models

Content

Any kind of graphical models that facilitate the understanding (of relationships) of Backlog Items. The diagrams should be linked to items from the Product Backlog.

Motivation

In the agile world, it has become widespread to write requirements in the form of epics, features or user stories on little cards or to file them in equivalent form in tools.

Nevertheless, communication among all stakeholders sometimes becomes much easier if you also use the tools we have come to know over the last decades to make the colloquial language more precise. So don’t be afraid to use models if they help communication.

Don’t worry: these models don’t have to be perfect. But especially with increasing complexity (loops or case distinctions), a graphical visualization of the steps of a business process promotes understanding better than many tickets in the system without recognizable sequences and dependencies.

Notations/Tools
  • Flowcharts

  • activity diagrams

  • BPMN

  • state models

  • data models

  • UI prototypes

  • mock-ups

  • wireframes

Simple modeling tools like Gliffy, Diagrams.Net (formerly DrawIO), ……, or DSLs like PlantUML, Kroki, … or UML modeling tools like Enterprise Architect, Visual Paradigm, MagicDraw are suitable for creating the models. The models should be linked to your backlog items (in both directions)

<Diagram Title 1:>. <insert diagram and explanations here > <optional: Link to Epics, Features or Stories>

<Diagram Title 2:>. <insert diagram and explanations here > <optional: Link to Epics, Features or Stories>

<Diagram Title 3:>. <insert diagram and explanations here > <optional: Link to Epics, Features or Stories>

.
.
.

<Diagram Title n:>. <insert diagram and explanations here > <optional: Link to Epics, Features or Stories>

6. Quality Requirements

Content

Quality requirements are the "how" to the "what" - qualitative definitions or precisions of the functional requirements.

Motivation

Our experience shows: Quality requirements are (unfortunately) still severely underestimated, not only in the agile world. Everyone wants good quality products and services, but only a few make it explicit what exactly is meant by this.

Some quality requirements (such as response times) can perhaps be integrated directly into a story (or added as an acceptance criterion). However, the vast majority of quality requirements relate to many, if not all, of the functional requirements in the product backlog.

Therefore, as a product owner, you need somewhere to specify and assign the desired qualities of your products and services. For this activity, industry-proven checklists (such as ISO 25010 and others) are available to help you quickly identify and manage the most important categories.

Notations/Tools

Simple textual scenarios, possibly structured according to the sections of Q42, or the ISO 25010 quality tree, or according to VOLERE.

< quality requirement or scenario 1> : <Link to functional requirements or scope for this quality >

< quality requirement or scenario 2> : <Link to functional requirements or scope for this quality >

< quality requirement or scenario 3> : <Link to functional requirements or scope for this quality >

.
.
.

< quality requirement or scenario n> : <Link to functional requirements or scope for this quality >

7. Constraints

Content

Technological or organizational (mandated) constraints for the development process, such as mandatory activities, prescribed documents and their content, milestones to be met, …

Motivation

Such constraints are also requirements. And since they often apply to several or even all functional requirements, they are difficult to accommodate in the ordered product backlog. Just make sure that all stakeholders know these constraints and have access to them when needed.

Form

Simple lists, possibly organized by category.

7.1. 7.1 Organizational Constraints

  • <OrgConstraint1>

  • <OrgConstraint2>

  • <OrgContraint3>

7.2. 7.2 Technical Constraints

  • <TechConstraint1>

  • <TechConstraint2>

  • <TechContraint3>

8. Domain Terminology

Content

A glossary of technical terms with definitions. The "ubiquitous language" of your domain

Motivation

Terms from your domain appear in every epic, feature, or story. These terms should be clear to everyone involved. And that’s why it is desirable to have a glossary of such terms for a project or product development.

Make sure that everyone involved speaks a common language - and has access to agreed-upon definitions of terms instead of bringing new words into play in every meeting.

Notations/Tools

Alphabetically ordered list of term definitions

Term

Definition

<Term-1>

<Definition-1>

<Term-2>

<Definition-2>

9. Assets

Content

Under assets we summarize everything that your sponsors or clients give you to enable you as a product owner (together with your team) to do your job successfully.

Assets definitely include time and budget, i.e., resources they give you to do your job. You may have to get your team with these resources yourself, or they may also provide you with staff (your team), workspace, infrastructure, etc.

Motivation

If you take on the job as a product owner you have to negotiate these assets with your sponsor or client and certainly in the end also account for their use (through hopefully successful results).

In any case, you should know what you have at your disposal in terms of money, personnel, time, infrastructure, … at your disposal. These assets are an essential boundary condition for your work as a product owner.

Notations/Tools

Simple lists or tables

9.1. 9.1 Budget

(possibly structured according to roadmap or intermediate goals, or divided into personnel budget, material budget, …)

9.2. 9.2 Time frame/final date

9.3. 9.3 Team members

(simple enumeration of team members for small team. Or a link to complex team structure in section 10).

9.4. 9.4 External resources

10. Teams

Content

This section can be omitted for small product developments with only one development team, since the team members are already listed in the previous section.

For scaled large products, the organization chart of your teams should be here and an assignment to the topics (e.g. epics, features, …) this team is responsible for.

Motivation

If you have more than one team at your disposal, it goes without saying that you should have an overview of who works in which (sub-)team and how these teams are organized.

The focus should be on (sub-)teams being organized in such a way that they can deliver functions/features or partial products as independently as possible without having to constantly coordinate with everyone else.

Notations/Tools

Lists of teams (each with assigned people and assigned topics from the roadmap or from the product backlog (e.g., epics or features).

Team

Team Members

Feature

<Team-1>

PO: <Person-1>

<Feature-A>

<Team member-2>

<Team member-3>

<Team-2>

PO_<Person-2>_

<Feature-B>

<Team member-2>

11. Roadmap

Content

"Delivery artifacts put on the timeline" - who delivers what and when?

Motivation

Agile projects also need a plan. The more distant a goal is, the less precise the plan can be. The closer, the more precise.

An explicitly known roadmap enables all participants to coordinate with each other and to think along with each other, and therefore to take into account what is still to come in the medium term when making short-term decisions.

If you only live from hand to mouth, you may unknowingly make short-term decisions that are contrary to longer-term product success. In our courses we show you how rough or fine a roadmap can, may or should be.

Notations/Tools

Whatever you have in use as a planning tool or which allows you to present, if possible on one page, an appropriate overview over a longer period of time.

< Insert your planning here>