Requirements Flashcards
What is the core software engineering process?
Specification
- Designing what the customer wants
Development
- Production of software system
Validation
- Checking that the software is what the customer wants
Evolution/Maintenance
- Changing code in response to new requirements
(silly developers value money)
Why are requirements important?
It is the most common cause of over-budgeting and unclear requirements can lead to project failure
What is stakeholder analysis?
Determining all the people that will use a system
What do we identify from stakeholder analysis?
Primary, secondary and tertiary stakeholders
What is a persona?
Represents a real type of user from stakeholders which are used to develop scenarios
What is a use case diagram?
Identities tasks each stakeholder/persona (actors) will do
What is a user story?
A single sentence to represent a single requirement
What is the structure of a user story?
As a <persona>, I want <use> so that I can <motivation></motivation></use></persona>
What are the advantages of doing user stories?
- Creates clear requirements checklist
- Breaks project down into chunks
- Can rank for importance
- Little maintenance
What are the disadvantages of user stories?
- Difficult to use in big projects
- Loose detail and formality
What is the difference between requirements and specifications?
Requirements are what a stakeholder must be able to do
Specifications is what the software must be able to do to meet requirements
How can we easily identify if something is a requirement or a specification?
Specifications typically start with a “the system shall”
Requirements typically start with a “the user wants”
What are the different types of requirements we can have?
Functional
- What the user should be able to do
Non functional
- Constraints on what the user needs to do and how well the system performs
How can we easily tell if something is a functional or non-functional requirement?
Functional
- “a user should”
Non-functional
- A description of what system does in a scenario
Give examples of functional and non-functional requirements?
Functional
- Allow user to log in, allow user to provide account creation, allow user to change password
Non-Functional
- Security, number of concurrent users
What are the three sub-genres of non-functional requirements?
Product requirements
- Generally to do with performance, when a job will happen, security etc.
Organisational requirements
- Regulations to do with the organisation the product is made for (login using unis authentication service, GDPR, budget constraints)
External requirements
- Third party requirements like disability support, web accessibility guidelines, paypal, environmental
What are some different investigation techniques?
- Surveys
- Interviews and focus groups
- Technology tours
- Ethnography
Explain the advantages and disadvantages of surveys?
Advantages
- Good for contacting lots of people
Disadvantages
- Can be a badly made questionnaire (try to ‘re-invent’ the wheel)
What are the characteristics of a good interview?
- Interviewer is ready to listen
- Interviewee is relaxed and chatty
What are the advantages and disadvantages of focus groups?
Advantages
- Talk to more people at one time
- Discuss different and opposing opinions
Disadvantages
- Possible conflict
- Can get a dominant speaker
- Takes longer to discuss per question
What are good things about observations?
Allows you to see the things people don’t say
What is a technology tour?
An overview of all the technologies a client uses
What is ethnography?
The idea that there is no better way to learn than doing
- Become part of the team for a while
What is a requirements model?
Models of important aspects of the system
What are different types of requirements models?
Context diagrams
Hierarchal tasks
UML diagrams
- Use case diagrams
- Activity diagrams
- Sequence diagrams
- Class diagrams
- State diagrams
Scenarios
When would we use a context diagram?
Showing related systems (non-functional requirements)
- Define boundaries of system
- Represents systems which need and do not need to be developed
When would we use a hierarchal task analysis?
For identifying subtasks
What UML diagrams would we use for behaviour diagrams?
Use case diagrams
Activity diagrams
Sequence diagrams
What UML diagrams would we use for structure diagrams?
Class diagrams
State diagrams
When would we use behaviour diagrams?
Requirements, specification and documentation
When would we use structural diagrams?
Specification and documentation
When would we use an activity diagram?
Used for elaborate work flows
Have decision and wait points
Show concurrent events
What symbols do we use in activity diagrams?
Diamonds for decisions
Bars to represent concurrent activities
When would we use a sequence diagram?
Good for complex sharing of information between people and systems
When would we use class diagrams?
Specify the classes in the code, more in development
When would we use class hierarchy diagrams?
To show levels of inheritance in OO code
When would we use a state diagram?
When we have a set of objects and states they can be in and want to model the behaviours in each state
What is a scenario?
A structured description of a process a persona does
What key things must a scenario do?
Plot describes how a user achieves a goal
- Defines a setting
- Defines actor
- Defines goals
- Defines plot
Who looks at the software requirement specification documents?
- System customers
- System engineers
- System test engineers
- System maintenance engineers
- Managers
Why do we do requirements validation?
- Checking that both client and developers are on the same page
- Avoid reworking
- Contractually agreeing
What are the two types of requirements validation?
Internal and external
Explain internal requirements validation
Present to ‘boss and colleagues’
- Get a clear picture before presenting to client
- Solve requirement conflicts
Explain external requirements validation
Present to participants/clients/users
- Develop a plan with client