The following establishes the data general and content
requirements for the identified data item. Document style, layout,
etc., shall conform to the Documentation Standard
and an example is provided by Software Development Plan - Model Text.
The Software Development Plan (SDP) describes a developer's plans for conducting a software development effort. The term "software development" in this DID is meant to include new development, modification, reuse, reengineering, maintenance, and all other activities resulting in software products.
The SDP provides the acquirer insight into, and a tool for monitoring, the processes to be followed for software development, the methods to be used, the approach to be followed for each activity, and project schedules, organization, and resources.
This Data Item Description (DID) contains the format and content preparation instructions for the data product generated by specific and discrete task requirements as delineated in the contract.
This DID is used when the developer is tasked to develop and record plans for conducting software development activities.
Portions of this plan may be bound separately if this approach enhances their usability. Examples include plans for software configuration management and software quality assurance.
The Contract Data Requirements List (CDRL) should specify whether deliverable data are to be delivered on paper or electronic media; are to be in a given electronic form (such as ASCII, CALS, or compatible with a specified word processor or other support software); may be delivered in developer format rather than in the format specified herein; and may reside in a computer-aided software engineering (CASE) or other automated tool rather than in the form of a traditional document.
This DID supersedes DI-MCCR-80030A, DI-MCCR-80297, DI-MCCR-80298, DI-MCCR-80299, DI-MCCR-80300, and DI-MCCR-80319.
General instructions.
Content requirements.
Content requirements begin on the following page. The numbers
shown designate the paragraph numbers to be used in the document.
1. Scope.
This section shall be divided into
the following paragraphs.
1.1 Identification.
This paragraph shall contain a full
identification of the system and the software to which this document
applies, including, as applicable, identification number(s), title(s),
abbreviation(s), version number(s), and release number(s).
1.2 System overview.
This paragraph shall briefly state
the purpose of the system and the software to which this document
applies. It shall describe the general nature of the system and
software; summarize the history of system development, operation,
and maintenance; identify the project sponsor, acquirer, user,
developer, and support agencies; identify current and planned
operating sites; and list other relevant documents.
1.3 Document overview.
This paragraph shall summarize the
purpose and contents of this document and shall describe any security
or privacy considerations associated with its use.
1.4 Relationship to other plans.
This paragraph shall describe the
relationship, if any, of the SDP to other project management plans.
2. Referenced documents.
This section shall list the number,
title, revision, and date of all documents referenced in this
plan. This section shall also identify the source for all documents
not available through normal Government stocking activities.
3. Overview of required work.
This section shall be divided into
paragraphs as needed to establish the context for the planning
described in later sections. It shall include, as applicable,
an overview of:
4. Plans for performing general software
development activities.
This section shall be divided into
the following paragraphs. Provisions corresponding to non-required
activities may be satisfied by the words "Not applicable."
If different builds or different software on the project require
different planning, these differences shall be noted in the paragraphs.
In addition to the content specified below, each paragraph shall
identify applicable risks/uncertainties and plans for dealing
with them.
4.1 Software development process.
This paragraph shall describe the
software development process to be used. The planning shall cover
all contractual clauses concerning this topic, identifying planned
builds, if applicable, their objectives, and the software development
activities to be performed in each build.
4.2 General plans for software development.
This paragraph shall be divided into
the following subparagraphs.
4.2.1 Software development methods.
This paragraph shall describe or reference
the software development methods to be used. Included shall be
descriptions of the manual and automated tools and procedures
to be used in support of these methods. The methods shall cover
all contractual clauses concerning this topic. Reference may be
made to other paragraphs in this plan if the methods are better
described in context with the activities to which they will be
applied.
4.2.2 Standards for software products.
This paragraph shall describe or reference
the standards to be followed for representing requirements, design,
code, test cases, test procedures, and test results. The standards
shall cover all contractual clauses concerning this topic. Reference
may be made to other paragraphs in this plan if the standards
are better described in context with the activities to which they
will be applied. Standards for code shall be provided for each
programming language to be used. They shall include at a minimum:
4.2.3 Reusable software products.
This paragraph shall be divided into the
following subparagraphs.
4.2.3.1 Incorporating reusable software
products.
This paragraph shall describe the
approach to be followed for identifying, evaluating, and incorporating
reusable software products, including the scope of the search
for such products and the criteria to be used for their evaluation.
It shall cover all contractual clauses concerning this topic.
Candidate or selected reusable software products known at the
time this plan is prepared or updated shall be identified and
described, together with benefits, drawbacks, and restrictions,
as applicable, associated with their use.
4.2.3.2 Developing reusable software products.
This paragraph shall describe the
approach to be followed for identifying, evaluating, and reporting
opportunities for developing reusable software products. It shall
cover all contractual clauses concerning this topic.
4.2.4 Handling of critical requirements.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for handling requirements designated critical. The planning in
each subparagraph shall cover all contractual clauses concerning
the identified topic.
4.2.5 Computer hardware resource utilization.
This paragraph shall describe the
approach to be followed for allocating computer hardware resources
and monitoring their utilization. It shall cover all contractual
clauses concerning this topic.
4.2.6 Recording rationale.
This paragraph shall describe the
approach to be followed for recording rationale that will be useful
to the support agency for key decisions made on the project. It
shall interpret the term "key decisions" for the project
and state where the rationale are to be recorded. It shall cover
all contractual clauses concerning this topic.
4.2.7 Access for acquirer review.
This paragraph shall describe the
approach to be followed for providing the acquirer or its authorized
representative access to developer and subcontractor facilities
for review of software products and activities. It shall cover
all contractual clauses concerning this topic.
5. Plans for performing detailed software
development activities.
This section shall be divided into
the following paragraphs. Provisions corresponding to non-required
activities may be satisfied by the words "Not applicable."
If different builds or different software on the project require
different planning, these differences shall be noted in the paragraphs.
The discussion of each activity shall include the approach (methods/procedures/tools)
to be applied to: 1) the analysis or other technical tasks involved,
2) the recording of results, and 3) the preparation of associated
deliverables, if applicable. The discussion shall also identify
applicable risks/uncertainties and plans for dealing with them.
Reference may be made to 4.2.1 if applicable methods are described
there.
5.1 Project planning and oversight.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for project planning and oversight. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.2 Establishing a software development
environment.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for establishing, controlling, and maintaining a software development
environment. The planning in each subparagraph shall cover all
contractual clauses regarding the identified topic.
5.3 System requirements analysis.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for participating in system requirements analysis. The planning
in each subparagraph shall cover all contractual clauses regarding
the identified topic.
5.4 System design.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for participating in system design. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.5 Software requirements analysis.
This paragraph shall describe the
approach to be followed for software requirements analysis. The
approach shall cover all contractual clauses concerning this topic.
5.6 Software design.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for software design. The planning in each subparagraph shall cover
all contractual clauses regarding the identified topic.
5.7 Software implementation and unit testing.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for software implementation and unit testing. The planning in
each subparagraph shall cover all contractual clauses regarding
the identified topic.
5.8 Unit integration and testing.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for unit integration and testing. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.9 CSCI qualification testing.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for CSCI qualification testing. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.10 CSCI/HWCI integration and testing.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for participating in CSCI/HWCI integration and testing. The planning
in each subparagraph shall cover all contractual clauses regarding
the identified topic.
5.11 System qualification testing.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for participating in system qualification testing. The planning
in each subparagraph shall cover all contractual clauses regarding
the identified topic.
5.12 Preparing for software use.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for preparing for software use. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.13 Preparing for software transition.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for preparing for software transition. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.14 Software configuration management.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for software configuration management. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.15 Software product evaluation.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for software product evaluation. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.16 Software quality assurance.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for software quality assurance. The planning in each subparagraph
shall cover all contractual clauses regarding the identified topic.
5.17 Corrective action.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for corrective action. The planning in each subparagraph shall
cover all contractual clauses regarding the identified topic.
5.18 Joint technical and management reviews.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for joint technical and management reviews. The planning in each
subparagraph shall cover all contractual clauses regarding the
identified topic.
5.19 Other software development activities.
This paragraph shall be divided into
the following subparagraphs to describe the approach to be followed
for other software development activities. The planning in each
subparagraph shall cover all contractual clauses regarding the
identified topic.
6. Schedules and activity network.
This section shall present:
7. Project organization and resources.
This section shall be divided into
the following paragraphs to describe the project organization
and resources to be applied in each build.
7.1 Project organization.
This paragraph shall describe the
organizational structure to be used on the project, including
the organizations involved, their relationships to one another,
and the authority and responsibility of each organization for
carrying out required activities.
7.2 Project resources.
This paragraph shall describe the
resources to be applied to the project. It shall include, as applicable:
8. Notes.
This section shall contain any general
information that aids in understanding this document (e.g., background
information, glossary, rationale). This section shall include
an alphabetical listing of all acronyms, abbreviations, and their
meanings as used in this document and a list of any terms and
definitions needed to understand this document.
A. Appendixes.
Appendixes may be used to provide
information published separately for convenience in document maintenance
(e.g., charts, classified data). As applicable, each appendix
shall be referenced in the main body of the document where the
data would normally have been provided. Appendixes may be bound
as separate documents for ease in handling. Appendixes shall be
lettered alphabetically (A, B, etc.).
Back to Home page MANAGING STANDARDS Home page
Please send any beneficial comments or identification of errors using the following form to: kenr@wysywig.airtime.co.uk