Here is the link of all of my posts on topic NFR:
Links:
- NFR : None Functional Requirement in Software Engineering or Application Development : Part 1
- NFR : None Functional Requirement in Software Engineering or Application Development : Part 2: Scalability, Performance, Testability
- NFR : None Functional Requirement in Software Engineering or Application Development : Part 3: Application Security
- NFR : None Functional Requirement in Software Engineering or Application Development : Part 4: Extensibility, Observability, Maintainability
NFR(None Functional Requirement) is abbreviated as Non Functional Requirement. In any application development or maintenance work, the NFRs are least discussed but most required activities. Generally, the NFRs of an application are not discussed by Business team. Its Developer's team's responsibility to discuss all the NFRs with business teams and try to understand and create a document of the discussion regarding NFRs implementation with Business team. There may be several discussion points regarding NFRs with Business team like:
- Expected minimum or maximum load on application
- What is the pick time and off pick time of the application usage
- Is the application public facing or only client's employee facing
- Application downtime required for build deployment or any upgradation
- Response throughput in terms of millisecond required for a feature
- Negotiation in business requirement to achieve the required throughput.
- Whether the application's feature is read extensive or write extensive to decide how frequently data should be flushed in caching if caching is implemented
- Whether customer requires latest data as soon as it is updated in system to decide whether to implement caching
- Cost of any 3rd party API that Business can bear.
- Cost of skilled resources that Business should bear till the time the application becomes stable(Should be discussed more by Management team)
- Tradeoff analysis and discuss with Business team about conflict between different NFRs.
- Scalability
- Performance
- Testability
- Security
- Extensibility
- Observability
- Maintainability