Software Engineering Lab
III Year B.Tech. CSIT- I Sem L/T/P/C
0/0/3/1.5
SOFTWARE ENGINEERING LAB ((2233PC62)
Course Objectives:
1. Discuss and Analyses how to develop software requirements specifications for a given
problem.
2. To understand Software development as a process
3. To implement various software designs, data flow diagram models.
Course Outcomes:
1. Ability to generate a high-level design of the system from the software requirements
2. Will have experience and/or awareness of testing problems and will be able to develop a
simple testing report
3. Understand and develop various structure and behavior UML diagrams.
4. Explain the knowledge of project management tool Demonstrate how to manage file using
Project Libre project management tool.
5. Various testing techniques including white box testing black box testing regression testing
6. To have hands on experience in developing a software project by using various software
engineering principles and methods in each of the phases of software development.
WEEK 1:
Development of problem statements.
WEEK 2:
Preparation of Software Requirement Specification Document, Design Documents and Testing
Phase related documents.
WEEK 3:
Preparation of Software Configuration Management and Risk Management related documents.
WEEK 4:
Study and usage of any Design phase CASE tool.
WEEK 5:
Performing the Design by using any Design phase CASE tools.
WEEK 6:
Develop test cases for unit testing and integration testing.
Department of CSIT Page 1
Software Engineering Lab
Sample Projects:
1. Passport automation System
2. Book Bank
3. Online Exam Registration
4. Stock Maintenance System
5. Online course reservation system
6. E-ticketing
7. Software Personnel Management System
Department of CSIT Page 2
Software Engineering Lab
8. Credit Card Processing
9. E-book management System.
10. Recruitment system
TEXT BOOKS:
1. Software Engineering, A practitioner’s Approach- Roger S. Pressman, 6th edition, McGraw
Hill International Edition.
2. Software Engineering-Sommerville, 7th edition, Pearson Education.
3. The unified modeling language user guide Grady Booch, James Rambaugh,
Ivar Jacobson, Pearson Education.
REFERENCE BOOKS:
1. Software Engineering, an Engineering approach- James F. Peters, Witold Pedrycz, John Wiley.
2. Software Engineering principles and practice-Waman S Jawadekar
Department of CSIT Page 9
Software Engineering Lab
DEPARTMENT OF COMPUTER SCIENCE INFORMATION TECHNOLIGY
SOFTWARE ENGINEERING Lab Manual (2233PC62)
TABLE OF CONTENTS
EXP NAME OF PAGE
NO: THE NO:
EXPERIMENT:
1 Development of problem statements 1-3
2 Preparation of Software Requirement Specification Document, Design
Documents and Testing Phase related documents 4-8
3 Preparation of Software Configuration Management and Risk Management
related documents 9-12
Study and usage of any Design phase CASE tool 13-16
4
5 Performing the Design by using any Design phase CASE tools 17-31
6 Develop test cases for unit testing and integration testing 32-37
7 Develop test cases for various white box and black box testing techniques 38-43
Department of CSIT Page 9
Software Engineering Lab
WEEK 1
AIM: To develop problem statements for a library management system.
Problem Statement:
Statement of a current issue/problem that requires timely action to improve the situation.
Process Flow of Library Management System:
A Book Bank lends books and magazines to member, who is registered in the system.
Also it handles the purchase of new titles for the Book Bank.
Popular titles are brought into multiple copies.
Old books and magazines are removed when they are out or date or poor in condition.
A member can reserve a book or magazine that is not currently available in the book bank, so that when it is
returned or purchased by the book bank, that person is notified.
The book bank can easily create, replace and delete information about the tiles, members, loans and
reservations from the system.
Components:
Problem
Proposed Solution
Solution(s) and its implementation steps
Roles & Responsibilities:
a) Librarian:
Admin
Adding & modifying books etc.
Inventory maintenance
b) Member:
Registered users
Search available books
Order & book return
c) System:
Notifications for overdue, availability of book etc.
Department of CSIT Page 1
Software Engineering Lab
I Inputs:
Author Name
Published Year
Price
Book ID
User details like id, password for logging in
Communication Details
Problems/Constraints:
Updating difficulties on account of adding of new books regularly.
Faster due date notification(s).
Internet Bandwidth
Unavailability of e-books
Department of CSIT Page 2
Software Engineering Lab
WEEK 2
AIM:
Preparation of Software Requirement Specification Document, Design Documents and Testing Phase
Related documents.
Preparation of Software Requirement Specification Document:
Users Characteristics:
Student: They are the people who desire to obtain the books and submit the information to the
database.
Librarian: He has the certain privileges to add the books and to approval of the reservation of books.
System Modules:
Log in: Secure registration of student and librarian by filling online registration form.
Book bank: Book bank contains all the books. New book added to the book bank with book no,
titlename, author, edition, publisher name details to the database. Any book is deleted if damaged.
Update of the book information also done.
Operations: student and administrator perform their operations like add book, delete book,update
information, view book details are implemented in log in Web Pages.
Non-functional requirements:
Privacy: privacy maintained for each and every user by providing user credentials username
and password.
Portability: installation on multiple platforms and execution of software.
Design Document:
Algorithm, Data Structure, Architecture and other support Information is maintained in a design
document.
Diagrams:
a. Use Case:
System details summary & all users in the system.
b. Activity:
System behavior (inclusive of dynamic aspects).
Department of CSIT Page 3
Software Engineering Lab
c. Sequence:
Message flow with the time stamp.
d. Class:
System Structure (Name, Attributes, Operations).
e. State Chart:
States specific to components/objects of a system.
f. Deployment:
System architecture with respect to execution.
Test Plan Document:
Test plan document contains all the catalog information of test strategies, objectives, schedule,
estimations and resources required to complete the project.
A “Test Case” refers to the actions required to verify a specific feature or functionality in software
testing.
Test Case Design Template:
Test Description: Test Expected Actual Pre- Pass/Fail: Remarks:
Case Steps: Results: Results: Requisites:
ID:
Department of CSIT Page 4
Software Engineering Lab
WEEK 3
AIM:
Preparation of Software Configuration Management and Risk Management related documents for library
management system.
Preparation of Software Configuration Management
Forms basis for End User License Agreement (EULA).
All the compatibilities of implementing the system can be known.
Software Requirements:
Operating System: Windows
7/10 Front end : J2EE
Back end : MySQL Server
IDE used : NetBeans
Hardware Requirements:
Processor: i3 or
higher RAM : 4 GB
Hard Disk drive: 500 GB
Risk Management:
Relates to the factors that have negative impact on the software project.
Categorized into
i. Known risks
ii. Unknown risks
Known risks are the “predictable” risks that can be easily categorized.
Example: Staffing, Code errors etc.
Unknown risks are the “unpredictable” risks that cannot be identified and categorized easily.
Example: Natural disasters, epidemic, recession etc.
Department of CI Page 5
Software Engineering Lab
Department of CI Page 6
Software Engineering Lab
WEEK 4
AIM:
Study and usage of any Design phase CASE tool
Design phase CASE tool:
CASE Tool: STARUML
How to Install StarUML on Windows 10
Star UML is a UML (Unified Modeling Language) tool introduced by MKLab. It is an open-source
modeling tool that supports the UML framework for system and software modeling. StarUML is
based on UML version 1.4, which provides 11 different types of diagrams and it accepts UML 2.0
notation. Version 2.0 was released for beta testing under a property license.
StarUML is actively supporting the MDA (Model Driven Architecture). It supports the UML profile
concept and allowing it to generate code for multiple languages. It also provides a number of
bug fixes and improved compatibility with the modern versions of the Windows Operating
System.
StarUML is mostly used by the Agile and small development teams, professional persons and
used by the educational institutes.
Features of StarUML:
1. It supports multi-platform such as Mac OS, Windows, and Linux.
2. It involves UML 2.x.standard compliant.
3. Includes Entity-Relationship Diagram (ERD), Data-Flow Diagram (DFD) and Flowchart
diagrams.
4. It creates multiple windows.
5. It has modern UX and dark and light themes.
6. Featured with retina (High-DPI) display support.
7. Includes model-driven development.
8. It has open Application Programming Interface (API).
Department of CI Page 7
Software Engineering Lab
9. Supports various third-party extensions.
10. Asynchronous model validation.
11. It can export to HTML docs.
Steps to Download and Install StarUML
Step 1: Go on the browser, type in the URL “StarUML”.
Step 2: Click on the very first search “Download-StarUML”.
Step 3: There will be 3 Operating Systems (OS) options, click on the option as per the devise OS.
Step 4: Now, right-click on the downloaded file, select “Show in Folder” option.
Step 5: Click on the open file, a popup window opens, click on the “Yes” button.
Step 6: Installation gets start. After installation popup opens to ask to buy a license. If you
want to click on the “Buy Now” button or else close that window. StarUML is ready to use.
Department of CI Page 8
Software Engineering Lab
Week 5
Aim:To design performance using Design phase CASE Tool.
CASE Tool:
StarUML Use Case
Diagrams:
The book bank use cases are:
1. book_issue
2. book_return
3. book_order
4. book_entry
5. search book_details
Actors Involved:
1. Student
2. Librarian
3. Vendor
I) Usecase Name: Search Book_Details
The librarian initiates this use case when any member returns or request the book and checking ifthe
book is available.
Precondition: The librarian should enter all Book details.
Normal Flow: Build message for librarian who search the book.
Post Condition: Send message to respective member who reserved the book.
II) Usecase Name: Book_ Issue
Initiated by librarian when any member wants to borrow the desired book. If the book is
available, the book is issued.
Precondition: Member should be valid member of library.
Normal Flow: Selected book will be issued to the member.
Alternative Flow: If book is not available then reserved book use case should be initiate. Post
Condition: Update the catalogue.
III) Usecase Name: Book_Order
Initiated by librarian when the requested book is not available in the library at that moment. The book
is reserved for the future and issued to the person when it is available.
Department of CI Page 9
Software Engineering Lab
Precondition: Initiatedonly when book is not available.
Normal Flow: It reserved the book if requested.
Post Condition: Mention the entry in catalogue for reservation.
IV) Usecase Name: Book_Return
Invoked by the librarian when a member returns the book.
Precondition: Member should be valid member of library.
Normal Flow: Librarian enters bookid and system checks for return date of the book.
AlternativeFlow: System checks for return date and if it returned late fine message will be displayed.
Post Condition: Check the status of reservation.
V) Usecase Name: Book_Entry
The purchase book use-case when new books invoke it or magazines are added to the library.
Precondition: Not available or more copies are required.
Normal Flow: Enter bookid, author information, publication information, purchased date, prize
and number of copies.
Post Condition: Update the information in catalogue.
Figure 1. Use case diagram for Book Bank System
Department of CI Page 10
Software Engineering Lab
Activity Diagrams:
They are used to describe the business and operational step-by-step workflows of components
in a system.
An activity diagram shows the overall flow of control.
Figure 2. Activity Diagram for Book Bank System [borrow book]
An activity is shown as a roundedbox containing the name of the operation. This activity
diagram describes the behavior of the system.
Department of CI Page 11
Software Engineering Lab
Figure 3. Activity Diagram for Book Bank System [order book]
Figure 4. Activity Diagram for Book Bank System [Return book]
Department of CI Page 12
Software Engineering Lab
Sequence Diagram:
A sequence diagram represents the sequence and interactions of a given USE-CASE or scenario.
Sequence diagrams can capture most of the information about the system.
Most object-to-object interactions and operations are considered events and events include signals,
inputs, decisions, interrupts, transitions and actions to or from users or external devices.
An event also is considered to be any action by an object that sends information. The event line
represents a message sent from one object to another, in which the “form” object is requesting an
operation be performed by the “to” object.
The “to” object performs the operation using a method that the class contains. It is also represented by
the order in which things occur and how the objects in the system sendmessage to one another.
Figure 5. Sequence Diagram for Book Issue & Return
Department of CI Page 13
Software Engineering Lab
Collaboration Diagram:
Figure 6. Collaboration Diagram for Book Issue & Return
Class Diagram:
The class diagram, also referred to as object modeling is the main static analysis diagram.
The main task of object modeling is to graphically show what each object will do in the problem
domain.
The problem domain describes the structure and the relationships among objects.
The ATM system class diagram consists of five classes:
1. Student
2. Book
3. Issue
4. Return
5. Vendor
6. Details
Department of CI Page 14
Software Engineering Lab
1) Student:
It consists of twelve attributes and three operations.
The attributes are enroll no, name, DOB, father name, address, dept name, batch and
book limits.
The operations of this class are addStInfo(), deleteStInfo(), modifyStInfo().
2) Book:
It consists of ten attributes and four operations.
This class is used to keep book information such as author, title, vendor, price, etc.
3) Issue:
It consists of eight attributes and two operations to maintain issue details such as, issue
date, acc no of issued book, name of the student who borrowed book.
4) Return:
It consists of eight attributes and two operations to maintain issue details such as, issue
date, acc no of issued book, name of the student who borrowed book.
5) Students:
The attributes of this class are name, dept, year, bcode no.
The operation is display students ().
6) Details:
The attributes of this class are book name, author, bcode no. The operations are delete
details().
Department of CSIT P a g e 15
Software Engineering Lab
Figure 7. Class Diagram for Book Bank System
State Chart Diagram
It consists of state, events and activities. State diagrams are a familiar technique to describe the
behavior of a system. They describe all of the possible states that a particular object can get into
and how the object's state changes as a result of events that reach the object.
Figure 8. State Chart Diagram for Book Bank System
Department of CSIT P a g e 16
Software Engineering Lab
Week 6
Aim: To develop test cases for unit testing and integration testing.
Unit Testing:
It is a software development process in which the smallest testable parts of an application,
called “units”, are individually scrutinized for proper operation.
Software developers and sometimes QA staff complete unit tests during the development process.
Integration Testing:
It is a type of software testing where components of the software are gradually integrated and then
tested as a unified group.
Usually, these components are already working well individually, but they may
break whenintegrated with other components.
Department of CSIT P a g e 17
Software Engineering Lab
Department of CSIT P a g e 18
Software Engineering Lab
Week 7
Aim: To develop test cases for various white box and black box testing techniques.
White Box Testing:
It is a form of application testing that provides the tester with complete knowledge of the application
Being tested, including access to source code and design documents.
Black Box Testing:
It is a form of testing that is performed with no knowledge of a system's internals, can be carried out
to evaluate the functionality, security, performance, and other aspects of an application.
Department of CSIT P a g e 19
Software Engineering Lab
Department of CSIT P a g e 20
Software Engineering Lab
Department of CSIT P a g e 21