258 lines
6.4 KiB
Markdown
258 lines
6.4 KiB
Markdown
|
<!-- markdownlint-disable-next-line first-line-h1 -->
|
||
|
##### Project
|
||
|
|
||
|
::PROJECT-NAME
|
||
|
|
||
|
##### Internal Release Number
|
||
|
|
||
|
::X.Y.Z
|
||
|
|
||
|
##### Attached worksheets
|
||
|
|
||
|
- SRS > [Use case suite](Use-Case-Suite)
|
||
|
- SRS > [Feature set](Feature-Set)
|
||
|
|
||
|
##### Related Documents
|
||
|
|
||
|
- [Project proposal](Proposal) > [User needs](User-Needs)
|
||
|
- ::LINKS TO RELEVANT STANDARDS
|
||
|
- ::LINKS TO OTHER DOCUMENTS
|
||
|
- [Glossary](Glossary)
|
||
|
|
||
|
---
|
||
|
|
||
|
**Process impact:** The SRS precisely defines the software product that
|
||
|
will be built. Decisions made in writing the SRS are based on
|
||
|
information in the [project proposal](Proposal) and [user
|
||
|
needs](User-Needs) documents. The SRS sets requirements that must
|
||
|
be satisfied by the [system design](Design). The SRS is verified
|
||
|
and validated by activities outlined in the [QA plan](QA-Plan).
|
||
|
|
||
|
### Introduction
|
||
|
|
||
|
_TODO: Provide a brief overview of this release of the product. You can
|
||
|
copy text from the project proposal, paste it here, and shorten it._
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
For more information, see the project [proposal](Proposal).
|
||
|
|
||
|
### Use Cases
|
||
|
|
||
|
::ONE PARAGRAPH OVERVIEW
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- Actors are described in the [user needs](User-Needs) document.
|
||
|
- The [use case suite](Use-Case-Suite) lists all use cases in an
|
||
|
organized way.
|
||
|
|
||
|
### Functional Requirements
|
||
|
|
||
|
::ONE PARAGRAPH OVERVIEW
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- The [feature set](Feature-Set) lists all features in an
|
||
|
organized way.
|
||
|
|
||
|
### Non-Functional Requirements
|
||
|
|
||
|
_TODO: Describe the non-functional requirements for this release. Some
|
||
|
examples are provided below._
|
||
|
|
||
|
#### What are the usability requirements?
|
||
|
|
||
|
::Our main criteria for making the system usable is the difficulty of
|
||
|
performing each high-frequency use case. Difficulty depends on the
|
||
|
number of steps, the knowledge that the user must have at each step,
|
||
|
the decisions that the user must make at each step, and the
|
||
|
mechanics of each step (e.g., typing a book title exactly is hard,
|
||
|
clicking on a title in a list is easy).
|
||
|
|
||
|
::The user interface should be as familiar as possible to users who
|
||
|
have used other web applications and Windows desktop applications.
|
||
|
E.g., we will follow the UI guidelines for naming menus, buttons,
|
||
|
and dialog boxes whenever possible.
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::Government customers will demand [section508
|
||
|
compliance](http://www.section508.gov/)
|
||
|
- ::Support learnability with principles of [Instructive
|
||
|
Interaction](http://www.foruse.com/articles/instructive.htm)
|
||
|
- ::The customer wants extensive on-line help, but is not demanding
|
||
|
a printed manual.
|
||
|
|
||
|
#### What are the reliability and up-time requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the safety requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the security requirements?
|
||
|
|
||
|
::Access will be controlled with usernames and passwords.
|
||
|
|
||
|
::Only administrator users will have access to administrative
|
||
|
functions, average users will not.
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::Passwords must be 4-14 characters long
|
||
|
- ::We will not use encrypted communications (SSL) for this website
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the performance and scalability requirements requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the maintainability and upgradability requirements?
|
||
|
|
||
|
::Maintainability is our ability to make changes to the product
|
||
|
over time. We need strong maintainability in order to retain our
|
||
|
early customers. We will address this by anticipating several types
|
||
|
of change, and by carefully documenting our design
|
||
|
and implementation.
|
||
|
|
||
|
::Upgradability is our ability to cost-effectively deploy new versions
|
||
|
of the product to customers with minimal downtime or disruption. A
|
||
|
key feature supporting this goal is automatic download of patches
|
||
|
and upgrade of the end-user's machine. Also, we shall use data file
|
||
|
formats that include enough meta-data to allow us to reliably
|
||
|
transform existing customer data during an upgrade.
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the supportability and operability requirements?
|
||
|
|
||
|
::Supportability is our ability to provide cost effective
|
||
|
technical support. Our goal is to limit our support costs to only 5%
|
||
|
of annual licensing fees. The product's automatic upgrade feature
|
||
|
will help us easily deploy defect fixes to end-users. The user guide
|
||
|
and product website will include a troubleshooting guide and
|
||
|
checklist of information to have at hand before contacting
|
||
|
technical support.
|
||
|
|
||
|
::Operability is our ability to host and operate the software as an
|
||
|
ASP (Application Service Provider). The product features should help
|
||
|
us achieve our goal of 99.9% uptime (at most 43 minutes downtime
|
||
|
each month). Key features supporting that are the ability to do hot
|
||
|
data backups, and application monitoring.
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the business life-cycle requirements?
|
||
|
|
||
|
::The business life-cycle of a product includes everything that
|
||
|
happens to that product over a period of several years, from initial
|
||
|
purchase decision, through important but infrequent use cases, until
|
||
|
product retirement. Key life-cycle requirements are listed below.
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::Customers must be able to manage the number of licenses that
|
||
|
they have and make informed decisions to purchase more licenses
|
||
|
when needed
|
||
|
- ::The product shall support daily operations and our year-end
|
||
|
audit
|
||
|
- ::The customer data shall be stored in a format that is still
|
||
|
accessible even after the application has been retired
|
||
|
|
||
|
### Environmental Requirements
|
||
|
|
||
|
_TODO: Describe the environmental requirements for this release.
|
||
|
Environmental requirements describe the larger system of hardware,
|
||
|
software, and data that this product must work within. Some examples are
|
||
|
provided below._
|
||
|
|
||
|
#### What are the system hardware requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the system software requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What application program interfaces ([APIs](Glossary-Standard-Terms#api_application_programming_interface)) must be provided?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::We must implement this [standard API](LINK-TO-STANDARD).
|
||
|
- ::DETAIL
|
||
|
- ::DETAIL
|
||
|
|
||
|
#### What are the data import and export requirements?
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
::PARAGRAPH
|
||
|
|
||
|
Details:
|
||
|
|
||
|
- ::The system will store all data in a standard SQL database, where
|
||
|
it can be accessed by other programs.
|
||
|
- ::The system will store all data in an XML file, using a
|
||
|
[standard DTD](LINK-TO-STANDARD).
|
||
|
- ::The system will read and write valid .XYZ files used by
|
||
|
OTHER APPLICATION
|
||
|
- ::DETAIL
|