KEMBAR78
Object Oriented Software Engineering Sample Lab Manual | PDF | Use Case | Class (Computer Programming)
67% found this document useful (3 votes)
4K views36 pages

Object Oriented Software Engineering Sample Lab Manual

This is a Sample Lab Manual for the Course "Object Oriented Software Engineering (OOSE)". It contains 11 experiments which cover various concepts of OOSE.

Uploaded by

Aiman Fatima
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
67% found this document useful (3 votes)
4K views36 pages

Object Oriented Software Engineering Sample Lab Manual

This is a Sample Lab Manual for the Course "Object Oriented Software Engineering (OOSE)". It contains 11 experiments which cover various concepts of OOSE.

Uploaded by

Aiman Fatima
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as PDF, TXT or read online on Scribd
You are on page 1/ 36

INDEX

1. To perform the Requirement analysis of the specified problem and draw a flow chart
2. Understanding of System modeling: Data model i.e. ER –Diagram and draw the ERDiagram
with generalization, specialization and aggregation of specified problem statement
3. Understanding of System modeling: Functional modeling: DFD level 0 i.e. Context Diagram
and draw it
4. Understanding of System modeling: Functional modeling: DFD level 1 and DFD level 2 and
draw it
5. Understanding different actors and use cases in detail of the specified problem statement and
draw it using Rational Rose software
6. To perform the user’s view analysis : Use case diagram and draw it using Rational Rose
software
7. To draw the structural view diagram: Class diagram of specified problem statement using
Rational Rose
8. To draw the behavioral view diagram: State-chart diagram, Activity diagram of specified
problem statement using Rational Rose
9. To understand testing and perform Boundary value analysis and Equivalence class testing
10. To draw Flow graph, DD paths, calculation of cyclomatic complexity and find out all the
independent paths from the DD paths graph
11. Case study: Prepare SRS for the problem statement
LAB WORK-I
--------------------------------------------------------------------------------------------------------------------
Title: Design of Flow Chart
Objective To perform the Requirement analysis of the specified problem and draw a flow chart

Theory:

Flowcharts are the ideal diagrams for visually representing business processes. For example, if you
need to show the flow of a custom-order process through various departments within your
organization, you can use a flowchart. This paper provides a visual representation of basic flowchart
symbols and their proposed use in communicating the structure of a well-developed web site, as well
as their correlation in developing on-line instructional projects. A typical flowchart from older
Computer Science textbooks may have the following kinds of symbols:

• Start and end symbols, represented as lozenges, ovals or rounded rectangles, usually
containing the word "Start" or "End", or another phrase signaling the start or end of a process,
such as "submit enquiry" or "receive product".
• Arrows showing what's called "flow of control" in computer science. An arrow coming from
one symbol and ending at another symbol signifies flow passes to the symbol the arrow
points to.
• Processing steps, represented as rectangles. Examples: "Add 1 to X"; "replace identified
part"; "save changes" or similar.
• Input/ Output represented as a parallelogram. Examples: Get X from the user; display X.
• Conditional (or decision) represented as a diamond (rhombus). These typically contain a
Yes/No question or True/False test. This symbol is unique in that it has two arrows coming
out of it, usually from the bottom point and right point, one corresponding to Yes or True,
and one corresponding to No or False. The arrows should always be labeled. More than two
arrows can be used, but this is normally a clear indicator that a complex decision is being
taken, in which case it may need to be broken-down further, or replaced with the "pre-
defined process" symbol.

A number of other symbols that have less universal currency, such as:

• A Document represented as a rectangle with a wavy base;


• A Manual input represented by a rectangle, with the top irregularly sloping up from left to
right. An example would be to signify data-entry from a form;
• A Manual operation represented by a trapezoid with the longest parallel side upmost, to
represent an operation or adjustment to process that can only be made manually.
• A Data File represented by a cylinder
Procedure:
1) Identify various processes, input/output and decision making statement of the system and
analyse it.
2) Use them to draw flow chart.
Start

Applicant

Selected Applicant from Merit List


Having unique AID (Expected to
take Admission)

Student reporting
Physically in
Campus for Adm.

Name
DOB
Generation of Enrolment Number and Course
mapping with AID Branch
Mother Name
Father Name
Generate Id card Blood Group
Enrolment
Number
Allotment of sections to student
according to branch

Attendance capturing by lecturer/Lab


attendant in the system using dual
interface

Student
Eligible for
Exam

Generate ADMIT CARD

Generation of Marks Obtained by Student


Tabulation captured/ entered by Examiner in
Result, Mark Dual Interface mode for Grade
Sheet and Degree Preparation
as per SD, Grade
Boundaries Mark Sheet and
calculated/define Tab Result Sheet
d in the system

End
LAB WORK-II
--------------------------------------------------------------------------------------------------------------------
Title: Draw E-R diagram for the specified system
Objective: To draw the ER-Diagram with generalization, specialization and aggregation.
--------------------------------------------------------------------------------------------------------------------
Theory: An entity-relationship model (ERM) is an abstract and conceptual representation of data.
Entity-relationship modeling is a database modeling method, used to produce a type of conceptual
schema or semantic data model of a system, often a relational database, and its requirements in a top-
down fashion. Diagrams created by this process are called entity relationship diagrams, ER diagrams,
or ERDs. The building blocks: entities, relationships, and attributes

An entity may be defined as a thing which is recognized as being capable of an independent existence
and which can be uniquely identified. An entity may be a physical object such as a house or a car, an
event such as a house sale or a car service, or a concept such as a customer transaction or order.
Entities can be thought of as nouns. Examples: a computer, an employee, a song, a mathematical
theorem. Entity sets are drawn as rectangles, relationship sets as diamonds. If an entity set
participates in a relationship set, they are connected with a line.

Weak Entity:
A weak entity is an entity that must defined by a foreign key relationship with another entity as it
cannot be uniquely identified by its own attributes alone.

A relationship captures how two or more entities are related to one another. Relationships can be
thought of as verbs, linking two or more nouns. Examples: a performs relationship between an artist
and a song, a proved relationship between a mathematician and a theorem.

Relationships illustrate how two entities share information in the database structure.

Attributes are drawn as ovals and are connected with a line to exactly one entity or relationship set

Key attribute
A key attribute is the unique, distinguishing characteristic of the entity. For example, an employee's
social security number might be the employee's key attribute.
Multivalued attribute:
A multivalued attribute can have more than one value. For example, an employee entity can have
multiple skill values.

Derived attribute:
A derived attribute is based on another attribute. For example, an employee's monthly salary is based
on the employee's annual salary.

Cardinality:
Cardinality specifies how many instances of an entity relate to one instance of another entity.
Ordinality is also closely linked to cardinality. While cardinality specifies the occurrences of a
relationship, ordinality describes the relationship as either mandatory or optional. In other words,
cardinality specifies the maximum number of relationships and ordinality specifies the absolute
minimum number of relationships.

Cardinality

One-to-one 1
1

One-to-many 1
n

Many-to-Many
n
m
Participation

Total

(Mandatory)

Partial

(Optional)

Specialization and Generalization:


Specialization is the procedure of defining a set of subclasses. The entity of which these subclasses
are parts is called the superclass of the specialization.
Allows for
• Defining set of subclasses of entity type
• Create additional specific attributes for each sub class
• Create additional specific relationship types between each sub class and other entity types or
other subclasses.
Generalization:
This can be thought of as the reverse procedure. This time we suppress the differences among several
entity types and identify their common features. For example, the entity types Car and Truck share
common attributes License, PlateNo, VehicleID and Price, therefore they can be generalized into the
super class Vehicle.

Constraints on Specialization and Generalization


• Several specializations can be defined on an entity type.
• Entities may belong to subclasses in each of the specializations.
• The specialization may also consist of a single subclass, such as the manager specialization;
in this case we don’t use the circle notation.
Output: A software training program is divided into training module, and each module is described
by module name and approximate practice time .Each module sometimes has prerequisite modules.
Model this situation of training programs and modules with an E-R diagram.
login-role-id
login-username
#login-id

user-password
User-name Login

#user-id
#role-id
User-mobile
Role-name
User
User-email Roles
HAS
User-address Role-desc

#per-id
Permission
Per-roleid
Stu-pass
#stu-id Manage Per-name
e
Per-module
Stu- Student
name
Stu-email
Stu-
mobile registration
Stu-add

Reg_dat Reg_id
Course e

Reg_type
#crs_id Crs_desc
Reg_desc
HAS
Crs_nam Crs_typ
colleges e e

Crs_stu_id
Coldesc
de
Col_id

Col_type
ER diagram of University Management System
login-role-id
login-username
#login-id

user-password
Login
User-name

#user-id
#role-id
User-mobile
Role-name
User
User-email Roles
HAS
User-address Role-desc

#per-id
Permission
Cus_pass Per-roleid
#cus_id Manage Per-name
e
Per-module
Cusname Customer
#pay_id
Cus-email
Cus-
Payments
mobile Cus-add

Pay_dat Pay_cu
e s_id
Booking

book_d Pay_amount
#book_id
esc Pay_desc
HAS
Cabs Bookdate book_type

Cab_id Booktitle
Cabtype de
Cab_desc

ER diagram of Transportation Management System


LABWORK –III

Title: Design of the System modeling.


Objective: Understanding of System modeling: Functional modeling: DFD level 0 i.e. Context
Diagram and perform it.
--------------------------------------------------------------------------------------------------------------------

Theory:
Data flow diagram:
Data flow diagrams are versatile diagramming tools. With only four symbols, data flow diagrams can
represent both physical and logical information systems. The four symbols used in DFDs represent
data flows, data stores, processes, and sources / sinks (or external entities).

Symbols of DFD:
A data flow is depicted as an arrow.
A rectangle or square is used for sources / sinks and its name states what the external agent is, such as
customer, teller, EPA office, or inventory control system.
The symbol for a process is a rectangle with rounded corners.
The symbol for a data store is a rectangle with the right vertical line missing. Its label includes the
number of data store.

External entity

Process

Data flow

Control flow

Data store Procedure:


1) Identify various processes, data store, input, output etc. of the system and analyse it.
2) Use processes at various levels to draw the DFDs.
3) Identify various modules, input, output etc. of the system and ask students to analyze.

Output:
Colleges Management

Registration
Management
Classes Management

University
Management
System

Courses Management

Students
Management

Faculties
Management

Zero Level DFD – University Management System


Customer details, bills
Customer Details or tickets

Transportation
and travelling
Management
Customer Employee
System

Bills or tickets Customer details,


bills or tickets

Zero Level DFD – Transportation Management System


LABWORK –IV

Title: Design of the System modeling.


Objective: Understanding of System modeling: Functional modeling: DFD level 1 and perform it.
--------------------------------------------------------------------------------------------------------------------
Tools/Apparatus: Rational Rose

Theory:
Data flow diagram
Data flow diagrams are versatile diagramming tools. With only four symbols, data flow diagrams can
represent both physical and logical information systems. The four symbols used in DFDs represent
data flows, data stores, processes, and sources / sinks (or external entities). Symbols of DFD
• A data flow is depicted as an arrow.
• A rectangle or square is used for sources / sinks and its name states what the external agent is,
such as customer, teller, EPA office, or inventory control system.
• The symbol for a process is a rectangle with rounded corners.
• The symbol for a data store is a rectangle with the right vertical line missing. Its label
includes the number of data store.

External entity

Process

Data flow

Control flow

Data store

Procedure:
1) Identify various processes, data store, input, output etc. of the system and analyse it.
2) Use processes at various levels to draw the DFDs.
3) Identify various modules, input, output etc. of the system and ask students to analyse.
Sample Output:
Collages Generate Collages
Management Report

Generate Classes
Classes Management Report

Students Generate Students


Management Report

University
Management
System
Faculties Generate Faculties
Management Report

Courses Management Check Courses


Details

Generate Registration
Registration Report
Management

Level-1 DFD – University Management System


Travel Agent Generate Travel
Management Agent Report

Customer Generate Customer


Management Report

Package Generate Package


Management Report
Travel and
Transportati
on
Management
Booking System
Generate Booking
Management Report

Transportation Check Transportation


Management Details

Generate Hotel
Report
Hotel Management

Level-1 DFD – Travel and Tour Management System


LABWORK –V

Title: To perform the user’s view analysis


Objective: Understanding different actors and use cases in detail of the specified problem
statement and draw it using Rational Rose

--------------------------------------------------------------------------------------------------------------------

Tools/Apparatus: Rational Rose

Theory:
Actors
• Are NOT part of the system – they represent anyone or anything that must interact with the
system.
• Only input information to the system.
• Only receive information from the system.
• Both input to and receive information from the system.
• Represented in UML as a stickman.

Use Case
• A sequence of transactions performed by a system that yields a measurable result of values
for a particular actor
• A use case typically represents a major piece of functionality that is complete from beginning
to end. A use case must deliver something of value to an actor

Use Case Relationships


• Between actor and use case.
• Association / Communication.
• Arrow can be in either or both directions; arrow indicates who initiates
communication. Between use cases (generalization):
Uses: Where multiple use cases share pieces of same functionality.
Extends
• Optional behavior.
• Behavior only runs under certain conditions (such as alarm). Several different flows run
based on the user’s selection.

Procedure:
1) Identify various processes, use-cases, actors etc. of the system and analyse it.
2) Use processes at various levels .
LABWORK –VI

Title: To perform the user’s view analysis


Objective: To draw Use case diagram using Rational Rose
--------------------------------------------------------------------------------------------------------------------
Tools/Apparatus: Rational Rose

Theory: The use-case diagram can provide the user’s view for designing of the software product.
And it can also be tested by matching up the requirements with the use-cases.

When to Use: Use Cases Diagrams


Use cases are used in almost every project. They are helpful in exposing requirements and planning
the project. During the initial stage of a project most use cases should be defined, but as the project
continues more might become visible.

Procedure:
1) Identify various processes, use-cases, actors etc. of the system and analyse it.
2) Use processes at various levels and draw use case diagram.

Output:
Use –Case Diagram of Transportation Management System
Use –Case Diagram of University Management System
LABWORK –VII

Title: To perform the structural view diagram


Objective: To perform Class diagram
--------------------------------------------------------------------------------------------------------------------
Tools/Apparatus: Rational Rose.

Theory: Class diagrams are widely used to describe the types of objects in a system and their
relationships. Class diagrams model class structure and contents using design elements such as
classes, packages and objects.2 Class diagrams describe three different perspectives when designing a
system, conceptual, specification, and implementation.1 These perspectives become evident as the
diagram is created and help solidify the design. This example is only meant as an introduction to the
UML and class diagrams. If you would like to learn more see the Resources page for more detailed
resources on UML.Classes are composed of three things: a name, attributes, and operations. Below
is an example of a class.

Procedure:
1) Identify various elements such as classes, member variables, member functions etc.of the
class diagram
2) Draw the class diagram as per the norms.

Output:
LAB WORK-VIII

Title: To perform the behavioral view diagram


Objective: To draw State-chart diagram, Activity diagram of specified problem statement using
Rational Rose
--------------------------------------------------------------------------------------------------------------------
Tools/Apparatus: Rational Rose

Theory: _State diagrams are used to describe the behavior of a system. State diagrams describe all
of the possible states of an object as events occur. Each diagram usually represents objects of a
single class and tracks the different states of its objects through the system. Statechart diagrams
represent the behavior of entities capable of dynamic behavior by specifying its response to the
receipt of event instances. Typically, it is used for _describing the behavior of classes, but statecharts
may also describe the behavior of _other model entities such as us ecases, actors, subsystems,
operations, or methods. Use state diagrams to demonstrate the behavior of an object through many
use cases of the system. Only use state diagrams for classes where it is necessary to understand the
behavior of the object through the entire system. Not all classes will require a state diagram and state
diagrams are not useful for describing the collaboration of all objects in a use case.

Activity diagrams describe the workflow behavior of a system. Activity diagrams are similar to
state diagrams because activities are the state of doing something. The diagrams describe the state of
activities by showing the sequence of activities performed. Activity diagrams can show activities
that are conditional or parallel. Activity diagrams show the flow of activities through the system.
Diagrams are read from top to bottom and have branches and forks to describe conditions and
parallel activities. A fork is used when multiple activities are occurring at the same time. The
diagram below shows a fork after activity1. This indicates that both activity2 and activity3 are
occurring at the same time. After activity2 there is a branch. The branch describes what activities
will take place based on a set of conditions. All branches at some point are followed by a merge to
indicate the end of the conditional behavior started by that branch.
After the merge all of the parallel activities must be combined by a join before transitioning into the
final activity state.
Procedure:
1) Identify various elements states and their different transition of the state-chart diagram 2)
Draw the state-chart diagram as per the norms.
3) Identify various elements such as different activity their boundaries etc. of the activity
diagram
4) Draw the activity diagram as per the norms.

Output:
Request
Scheme

New Customer

New Tour
Registered Customer Register Information
Customer

Select Tour
Package/ Select
Travel Plan

More packages

Reserve Tickets

Make Payment

State Chart Diagram of Transportation Management System


State Chart Diagram of University Management System
LAB WORK-IX

--------------------------------------------------------------------------------------------------------------------
Title: Design Test Cases.
Objective: To perform Boundary value analysis and Equivalence Class Testing.
--------------------------------------------------------------------------------------------------------------------

Theory:
Boundary value analysis is a software testing technique in which tests are designed to include
representatives of boundary values. The expected input and output values should be extracted from
the Component specification. The input and output values to the software component are then
grouped into sets with identifiable boundaries

Procedure:
Boundary values Testing
1. First try to identify different inputs and output of the
problem Statement.
2. Write down Boundary/edge value i.e. minimum, minimum-, nominal, maximum and
maximum+ value of each input
3. Create Test cases by putting each value at the edge / boundary value and other at nominal
value for Boundary values Testing

Equivalence class testing


1. First try to identify different inputs and output of
the problem Statement
2. Create as many valid and invalid input classes of identified inputs 3. Create Test
cases by taking value from each valid and invalid input.

Sample Output:

i) Boundary/edge value of each input


ii)
Value Input 1(A) Input 2(B) Input
3(C)
Min 1 1 1
Min+ 2 2 2
Nominal 100 100 100
Max- 199 199 199
Max 200 200 200

Test case Test Input Expected Actual


Description case Id Output Output
A B C
Keep side A at 1 1 100 100 Isosceles Isosceles
edge value triangle triangle
and other at
nominal value

Keep side B 2 100 1 100 Isosceles Isosceles


at edge value triangle triangle
and other at
nominal
Keep side C 3 100 100 1 Isosceles Isosceles
at edge value triangle triangle
and other at
nominal
Equivalence class testing:
I1=<a, b, c: three valid equal sides>
I1=<a ,b, c: two valid equal sides>
I1=< a, b, c: two valid equal sides and one invalid side>
O1=<a, b, c: Equilateral Triangle >
O2=<a, b, c: Isosceles Triangle >
O3=<a, b, c: Scalene Triangle>
O4=<a, b, c: Invalid Input>

Test case Test Input Expected Actual


Description case Id Output Output
a b c
Three valid 1 7 7 7 Equilateral Equilateral
equal sides triangle triangle
Two equal 2 5 6 5 Isosceles Isosceles
valid sides triangle triangle
Two equal 3 2 2 220 Error msg: Error msg:
valid sides; invalid invalid
Third side Input data Input data
invalid value value
LAB WORK-X
--------------------------------------------------------------------------------------------------------------------
Title: Design Test Cases.
Objective: To draw Flow graph, DD paths, calculation of cyclomatic complexity and find out all the
independent paths from the DD paths graph.
--------------------------------------------------------------------------------------------------------------------

THEORY: Brief description of white box testing and cyclomatic complexity.

PROCEDURE:
STEP 1: Analyze the source code
STEP 2: Draw Flow Graph
STEP 3: Draw the following DD Path Graph
STEP 4: Create decision table to find out the independent paths.
STEP 5: Calculate Cyclomatic Complexity V(G)
STEP 6: Identify independent paths and execute it.

STEP 1: Analyze the source code

PROGRAM:
#include<stdio.h>
#include<conio.h>

(1). int main()


(2). {
(3). int a,b,c, boolean =0;
(4).printf(“\n Enter the side A:”);
(5). scanf(“%d”, &a);
(6).printf(“\n Enter the side B:”);
(7). scanf(“%d”, &b);
(8)..printf(“\n Enter the side C:”);
(9). scanf(“%d”, &c);
(10). if((a>0) && (a<-100) && (b>0) && (b<100) && (c>0) && (c<=100)){
(11). if((a+b>c) && ((c+a)>b) && ((b+c)>a){
(12). boolean =1
(13).}
(14).}
(15). else {
(16) boolean = -1;
(17) }
(18) if (boolean = = 1) {
(19) if ((a = =b) && (b = =c)) {
(20) printf ("Triangle is equilateral");
(21) }
(22) else if ((a = =b) I I (b = = c) I I (c = = a)) {
(23) print ("Triangle is isosceles");
(24) }
(25) else {
(26) printf("Triangle is scalene”);
(27) }
(28) }
(29) else if (boolean = = 0) {
(30) printf ("Not a triangle");
(31) }
(32) else
(33) printf ("\n invalid input range");
(34) }
(35) getch ( );
(36) return -1;
(37) }

SAMPLE::
OUTPUT Draw Flow Graph of Triangle Problem
DD Path Graph: Since, nodes 1-9 are sequential nodes in the above flow graph, hence they are
merged together as a single node – “a”. Likewise we can go on deciding the merging of nodes &
arrive at the following DD Path Graph
Following Decision Table::
Nodes in Corresponding
the flow Nodes of DD
Graph Path Graph Justification

1-9 a Are Sequential


nodes

10 b Decision Nodes

11 C Decision Nodes

12,13 d Sequential nodes

14 e Two Edge
Combined

15,16,17 f Sequential nodes

18 g Decision Nodes

19 h Decision Nodes

20,21 i Sequential nodes

22 j Decision Nodes

23,24 k Sequential nodes

25,26,27 l Sequential nodes

28 m Three edge
combined

29 n Decision Nodes

30,31 o Sequential nodes

32,33,34 p Sequential nodes

35 q Three edge
combined

36,37 r Sequential Exit


Node
Calculation of Cyclomatic Complexity V (G) by three methods::

Method – 1: V(G) = e – n + 2 ( Where “e” are edges & “n” are nodes)
V(G) = 23– 18+ 2 = 5 + 2 = 7

Method – 2: V(G) = P + 1 (Where P – No. of predicate nodes without degree = 2)


V(G) = 6 + 1 = 7 (Nodes b, c, g, h, j & n are predicate nodes with 2 outgoing edges)

Method – 3: V(G) = Number of enclosed regions + 1 = 6+1=7


(Here R1, R2, R3, R4, R5 & R6 are the enclosed regions and 1 corresponds to one
outer region)
V (G) = 7 and is same by all the three methods.

Identification of the basis-set with Seven Paths


Path 1: a – b – f – g – n – p – q – r
Path 2: a – b – f – g – n – o – q – r
Path 3: a – b – c – e – g – n – p – q – r
Path 4: a – b – c – d – e – g – n – o – q – r
Path 5: a – b – f – g – h – i – m – q – r
CASE STUDY: Software Requirement Specification (SRS)

1. Objectives

• Gain a deeper understanding of the Software Requirement Specification phase and the
Software Requirement Specification (SRS).
• Learn how to write requirements and specifications.
• Gain exposure to requirements management using RequisitePro.

2. Background
A requirement is a statement of a behavior or attribute that a system must possess for the system to be
acceptable to a stakeholder.
Software Requirement Specification (SRS) is a document that describes the requirements of a
computer system from the user's point of view. An SRS document specifies:
• The required behavior of a system in terms of: input data, required processing, output data,
operational scenarios and interfaces.
• The attributes of a system including: performance, security, maintainability, reliability,
availability, safety requirements and design constraints.
Requirements management is a systematic approach to eliciting, organizing and documenting the
requirements of a system. It is a process that establishes and maintains agreement between the
customer and the project team on the changing requirements of a system.
Requirements management is important because, by organizing and tracking the requirements and
managing the requirement changes, you improve the chances of completing the project on time and
under budget. Poor change management is a key cause of project failure.

2.1 Requirements Engineering Process


Requirements engineering process consists of four phases:
• Requirements elicitation: getting the customers to state exactly what the requirements are.
• Requirements analysis: making qualitative judgments and checking for consistency and
feasibility of requirements
• Requirements validation: demonstrating that the requirements define the system that the
customer really wants.
• Requirements management: the process of managing changing requirements during the
requirements engineering process and system development and identifying missing and extra
requirements.

2.2 Writing Requirements


Requirements always need to be correct, unambiguous, complete, consistent, and testable.

2.2.1 Recommendations When Writing Requirements


• Never assume: others do now know what you have in mind.
• Use meaningful words; avoid words like: process, manage, perform, handle, and support.
State requirements not features:
➢ Feature: general, tested only for existence.
➢ Requirement: specific, testable, measurable.
Avoid:
➢ Conjunctions: ask yourself whether the requirement should it be split into two
requirements.
➢ Conditionals: if, else, but, except, although.
➢ Possibilities: may, might, probably, usually.

2.3 Writing Specifications


Specification is a description of operations and attributes of a system. It can be a document, set of
documents, a database of design information, a prototype, diagrams or any combination of these
things.
Specifications are different from requirements: specifications are sufficiently complete ─ not only
what stakeholders say they want; usually, they have no conflicts; they describe the system as it will
be built and resolve any conflicting requirements.
Creating specifications is important. However, you may not create specifications if:
• You are using a very incremental development process (small changes).
• You are building research or proof of concept projects.
• You rebuilding very small projects.
• It is not cheaper or faster than building the product.

2.4 Software Requirement Specification (SRS)


Remember that there is no “Perfect SRS”. However, SRS should be:

• Correct: each requirement represents something required by the target system.


• Unambiguous: every requirement in SRS has only one interpretation
• Complete: everything the target system should do is included in SRS (no sections are marked
TBD-to be determined).
• Verifiable: there exists some finite process with which a person/machine can check that the
actual as-built software product meets the requirements.
• Consistent in behavior and terms.
• Understandable by customers.
• Modifiable: changes can be made easily, completely and consistently.
• Design independent: doesn't imply specific software architecture or algorithm.
• Concise: shorter is better.
• Organized: requirements in SRS are easy to locate; related requirements are together.
• Traceable: each requirement is able to be referenced for later use (by the using paragraph
numbers, one requirement in each paragraph, or by using convention for indication
requirements)
REFERENCES

[1] An Integrated Approach to Software Engineering Pankaj Jalote.


[2] Software Engineering K.K Aggarwal & Yogesh Singh
[3] Software Engineering Roger Pressman McGraw Hill
[4] Visual Modeling with Rational Rose 2000 and UML Terry Quatrani
[5] https://creately.com

You might also like