layout | title |
---|---|
page |
Software Requirements and Design |
20 January 2017
There are three parts to this lecture.
Last week, I talked about the ten desirable properties of software requirements. In this lecture, we get some practice about this.
Here is a preliminary software requirements taken from one of the past projects for you to comments on what's good about the requirements and what's there to improve upon, based on the ten desirable properties:
Building a secure system is more than adding "The system should be secure" as a non-functional requirement. Some functionalities have to be included into the system to ensure the security of the system. Security is not a feature. It is a property that emerges after sufficient number security-related mechanisms are implemented.
Security can often be included as a constraint (e.g., "precondition: user must be authenticated" for a "transfer money" use case). Another way security can be specified is by listing the anti-behavior, i.e., list down what users should not do. We then counter these anti-behavior with added constraints or functional requirements.
One way to think about security is to consider the different categories of threats: + Spoofing: can the user pretend to be someone else? + Tampering: can the user tamper with the data? + Repudiation: can the user deny ever performing an action? + Information disclosure: can the user see something he/she is not supposed to see? + Denial of service: can the user overload or crash the system? + Elevation of privilege: can the user gain more privilege than intended?
- As a customer I want to login with my username and password so that I can access my bank account online
- As a customer I want to transfer money to another account after I login
- As a customer I want to be able to logout after I login
- As a costumer I want to reset my password when I forgot what my password is so that I will not lose access to my account.
We will fill this in during class
If your team already has sufficient ideas about what to implement for your project, it is now time to think about how to implement it. This step is where you plan your implementation details, from what are the major components of the system, what languages/libraries/frameworks/databases to use, what algorithms/data structures to use, what the UI would look like, what are the key tables in your database, etc. You may even start a small prototype to explore the options you have.
For your project, the design and architecture are expected to change over time. You should, however, still have sufficiently detailed and stable design to move on to the implementation phase.
Key decisions to be made during the design phase are:
- which framework/library to use?
- what platform to support?
- what’s the database schema?
- what the UI looks like?
- what are the major components? how do they interact?
- what are the APIs?
- no fix rules here, just be simple, clear, and consistent
- can have more than one:
- one for development view (classes, tables, etc)
- one for physical view (server, phones, laptops, etc)
- one for logical view (server, client, database, etc)
- be very clear yourselves what boxes and arrows mean
- common mistake: e.g., an arrow means inheritance in some parts of diagrams, means the sequence of flow in other parts, and means passing data from one component to the next in yet another part.
- common mistake: arrows without labels
- rules of thumb: if a diagram is not readable on 1-page A4 print out, it is not useful