1.6 KiB
1.6 KiB
title |
---|
Nonfunctional Requirements |
Nonfunctional Requirements
A non-functional requirement (NFR) is a requirement that specifies criteria that can be used to judge the operation of a system, rather than specific behaviors (a functional requirement). Non-functional requirements are often called "quality attributes", "constraints" or "non-behavioral requirements".
Informally, these are sometimes called the "ilities", from attributes like stability and portability. NFRs can be divided into two main categories:
- Execution qualities, such as safety, security and usability, which are observable during operation (at run time).
- Evolution qualities, such as testability, maintainability, extensibility and scalability, which are embodied in the static structure of the system
Usually you can refine a non-functional requirement into a set of functional requirements as a way of detailing and allowing (partial) testing and validation.
Examples:
- The printer should print 5 seconds after the button is pressed
- The code should be written in Java
- The UI should be easily navigable
More Information:
- Wikipedia article
- ReQtest Explains the difference between functional and nonfunctional requirements
- Scaled Agile Works through the process from finding to testing nonfunctional requirements