Group Assignment Technology Park Malaysia CT046-3-2 System Development Methodology NP2F1909IT
Group Assignment Technology Park Malaysia CT046-3-2 System Development Methodology NP2F1909IT
Group Assignment Technology Park Malaysia CT046-3-2 System Development Methodology NP2F1909IT
___________________________________________________________________________
INSTRUCTIONS TO CANDIDATES:
2. Students are advised to underpin their answers with the use of references (Cited using
the Harvard Name System of referencing).
3. Late submissions will be awarded zero (0) unless extenuating Circumstances (EC) is
upheld.
6. Where the assignment should be submitted in both hard copy and softcopy, the
softcopy of the written assignment and source code (where appropriate) should be on a
CD in an envelope/ CD cover and attached to the hardcopy.
NP2F1909IT
We have taken efforts to do this project. However, it would not have been possible without the
help and kind support of many individuals and Lord Buddha Education Foundation (LBEF).
We would like to extend our deepest gratitude to all of them who provided us with immense
support.
We are highly indebted to Mr. Ravi Rauniyar for his guidance and constant supervision as well
as for providing necessary information regarding the project and for his support in completing the
project.
We would like to express our sincere thanks to our parents and friends for their continuous co-
operation and encouragement, which made this assignment, happen.
Our heartily thanks and appreciations also go to our colleague for helping us in doing this
assignment and people who have willingly helped us out with their abilities in completion of this
assignment.
Sincerely,
1
1.2. Scope
In today’s busy world most of us lack in time to visit a restaurant and have lunch. So, the demand
of home delivery services is increasing rapidly. As the business of home delivery is expanding,
there is a need of order management system and an online food delivery tracking system to manage
all the business processes digitally. Also, this is the era of digitalization and automation every
business has started to shift towards using technology. Due to these reasons the need of building
this project is crucial.
1.3. Objective
i. To automate the process of ordering and delivery.
ii. To provide a user-friendly interface and to make ordering convenient to the customers.
iii. To develop a system that can process a huge amount of orders at a time.
iv. To make ease in communication between client the server.
v. To reduce the time taken for ordering and take efficient actions after the order is placed.
1.4. Aim
i. To manage the overall functions of the waiter on wheels business in an effective and
accurate manner.
ii. To reduce the manual entries made for order processing.
iii. To maintain day-to-day records and make analytic decisions from those records.
2
2. Agile Principles:
Agile methodology is the set of modern Information System (IS) methodology which shares agile
principles, defined in “The Agile Manifesto”, and was developed by software developers in 2001.
The methodology for project management which stands out from the rest is Agile Methodology.
Agile is the most effective technique for project management according to profession research.
The Agile Manifesto’s developers initially concentrated on software development because they
have been employed in the IT industry. Agile project management techniques have expanded
beyond software development and even beyond the computer related products. (Hasan, 2020)
i. The highest priority is customer satisfaction by delivering valuable software early and
continuously. As a developer of web-based software using an agile approach, we need
to make sure that we produce a product that solves user problems. It ensures timely
delivery for the home delivery system.
ii. Even in late development, it embraces the changing requirements and agile method
harnessing change for a competitive advantage of the customer. Perhaps, the biggest
advantage is that it gives flexibility to change. For delivery system, it allows changes
to be made even late in the development process and reduces the time for change
between conception and implementation.
iii. Working software is delivered frequently with focus on shorter timescale. Agile
methodology minimizes the documentation and planning and focus more on
development. In case of computerized delivery, it provides instant values to the
customer by delivering before the deadline.
iv. Developers and business people will work together every day. In computerized delivery
system it maintains collaboration and task management between the restaurant manager
and the waiters.
v. Projects are built around the motivated person with the resources and supportive
environment to get the job done and also hire the right people to work. In delivery
tracking system, it makes team to be self-reliant and self-directed.
3
vi. Face-to-face conversation is most efficient way to convey information between the
team members. For the delivery system we must obtain straight feedback of the
problem through the face to face conversation between team members.
vii. The primary measures of favorable results are working software. Regardless of how
many problems we fixed in the delivery system, or how many hours we put in the
development of software, the only things that count is working product.
viii. Sustainable development able to maintain a constant pace through sponsors, developers
and users. In agile methodology, the work is carried out in short, productive bursts to
ensure improved productivity and positive results.
ix. Constant attention to technical excellence and good design can improve agility. In
computerized delivery system, it helps to enhance the development speed so that we
can achieve more in less time without losing the quality of the final software.
x. Simplicity is essential to maximize the amount of work not done. We should keep
things simple while developing software using agile methodology, and reduce the time
needed to go from understanding to completion.
xi. The best design, construction and specifications come from teams which are self-
organized. In computerized delivery tracking system, it will themselves find a way and
remove any obstacles that comes in the way and makes everything going smoothly.
xii. Regularly, the team reflects on how to become more effective and behave accordingly.
It is critical that we continue to look for and develop vulnerabilities in today’s complex
agile project environments. It helps to keep pace with the emerging trends and adjust
to suit the situation in order to achieve. (LAYTON, 2020)
4
3. IS Methodologies:
Information System (IS) methodologies was developed in the mid 1980’s. Information system
methodologies is one of the traditional methodologies which focus primarily on quick delivery of
software and client satisfaction. It is one of the flexible stages which focus on product excellence
and documentation. Some Information System methodologies are listed below:
Different Information System (IS) methodologies we have chosen to make computerized delivery
tracking system. They are described below:
5
3.2. RAD Methodology:
Rapid Application Development (RAD) is a software development approach that emphasis on
rapid prototyping of the software, quick and iterative delivery of the product. Therefore, RAD is
alternative to the typical waterfall development methodologies, which focuses on planning and
design processes.
Advantages of RAP
Advantages of RUP:
The project risks associated with client’s requirements can be proactively resolved.
The need for integration is very less as the integration process continues throughout the
development process more specifically in the construction phase.
6
3.4. Comparison Table of IS Methodologies:
Facts Waterfall XP RAD RUP SCRUM
7
4. System Analysis:
System analysis and design are concerned with designing and implementation of information
systems by identifying and explaining what the system should exactly do. It also deals about how
the system components should be implemented together. By evaluating the information system
requirements and implementing those systems using different design techniques, a system analyst
can solve various business issues. (Balpan, 2017)
8
4.1.1. Requirement Discovery:
Requirement Discovery, also called requirement gathering and analysis, is the process of
communicating with stakeholders and collecting the required information from them. Requirement
discovery can be achieved by different methods, such as interviews, meeting, brainstorming
sessions and many more. (ELGABRYs, 2016)
9
5. System Design:
5.1. Conceptual Diagram: Use Case Diagram
A use case diagram is an initial state of system requirements for an underdeveloped software. It is
the representation of expected behaviour but nut how it is going to happen. The main feature of
use case diagram is that it helps us in designing a system from end user's perspective. There are
five main components in this diagram i.e. Use cases, actors, associations, system boundaries and
packages. The reasons for choosing Use case diagram for this project are listed below:
i. Use case diagram help to specify the functional requirements of the system.
ii. It helps to understand the user interaction goals for a system.
iii. It helps is designing the basic flow of events for a system.
iv. It is easy to understand so even a lay man can understand it easily.
10
Figure 3: Use case Diagram of Waiters on Wheel
11
5.2. Logical Design: Entity Relationship Diagram
Entity relationship Diagram is a logical diagram that represents the relationship between entity
sets. It shows the logical structure of a database as viewed by end users. It helps in determining
the entities, their attributes and relationships between entities. An ERD can be composed of three
main components i.e. Entity, Attributes and Relationships. The reasons behind choosing ERD as
a logical design for our project are listed below:
i. ERD is very simple and easy to draw. If the relationships between entities and attributes
are known then we can simply draw an ERD.
ii. It is clearly understandable. By seeing this diagram one can easily understand
relationships between entities and attributes.
iii. It is very easy to convert an ERD to a different data model.
12
Figure 5: Class Diagram of Waiter on Wheel Restaurant
Here, class diagram of waiter on wheel is designed. The class name in the above diagram includes
cash on delivery, system order, customer details and bank account details for the online payment
in the restaurant.
13
5.3. Physical Design: Prototype
Prototype is a practical explanation of how a system will work and behave. It is an early sample
of release of a product to make tests before releasing it to a client. It is mainly built to check for
bugs and errors. The reasons behind choosing Prototype as a physical design are listed below:
14
Figure 7: Order Menu of Restaurant
15
6. Implementation and Deployment:
6.1. Construction:
While constructing the Computerized Delivery Tracking System, the major software and tools that
are used or considered during construction are described below:
16
7. Testing:
Testing is an evaluation process for detecting discrepancies between the specified input and the
expected out. Testing checks whether the computerized delivery tracking system will meet the
stated requirements in order to deliver a quality product or not. There are various types of testing,
they are as follow: (Syantini, 2019)
1. Unit Testing:
Unit testing refers to an individual unit or a group of linked units. This testing is performed to
check whether the implemented software is producing expected output against the given input.
During unit testing in computerized delivery tracking system, code is tested in individual unit.
2. Integration Testing:
Integration testing combines a group of components to produce expected output. Often, software-
hardware interaction is evaluated in integration testing. During integration testing in computerized
delivery tracking system, whole code is tested for making a system.
3. Functional Testing:
Functional testing ensure that the system requirements operates with the specified functionality of
the system. During functional testing of computerized delivery tracking system, the whole code is
checked and determined whether it is functional or not, if not then it is modified further.
4. System Testing:
System testing is the testing which ensures that the software still function by bringing them into
different environments. It is carried out with full implementation of the application and its
environment. During system testing of computerized delivery tracking system, the whole code
checked for its performance, either it is working properly or not.
17
8. System Deployment:
18
9. Individual Component
i. Communication
A good communication among the team members will greatly reduce the problems
arising and result in high output of the team. Working in a team brings out the best
solutions to any problems.
ii. Simplicity
If we are developing a software then we must try to make it simple and clear focusing
on the functionalities that is needed at the moment rather than the functionalities to be
used in the future.
19
iii. Feedback
No any software remains valid for a long time. We must make frequent changes to the
system according to the need of clients. This is possible only when we receive regular
feedback from the client.
iv. Courage
Courage is effective action in the face of fear. (Beck and Andres, 2005) Every team
member should have courage to speak truth about the progress and problems arising
and to discard the failing solutions and search for the new ones.
v. Respect
Every team member should respect each other and their work. To improve the
productivity, everyone's contribution on the team must be respected.
20
4. Metaphor
It is a system architecture that is to be built in a way that can be easily understood by everyone
involved in the department. It is a document that clearly describes the complete working of the
system and provides a vision that states system purpose and scope. (Yasvi, M., 2019).
5. Continuous testing
It simply tells that developers generates tests for each and every function, after those functions
passes the tests it is released to customers.
6. Code Refactoring
It is just simplifying a code to make it easier to understand. Here the duplicate codes are
eradicated. In XP we don't use complex codes, long methods or unnecessary classes. After
adding a feature to the system, developers try to find a way to make it simple, and so they
refactor the code to make it simple.
7. Pair Programming
Two developers work on a same machine to write the same code. One is for writing code while
the other is for reviewing.
8. Collective code ownership
There's no any specific member for a specific function. Anyone can work in any part of the
system at any time.
9. Continuous Integration
If there is any change to be made on the system it must be integrated regularly to be sure that
it works before and after the integration.
10. 40-Hour work week
Developers should keep a balance in their work-life it prevents from getting stressed and
burnout. Overtime are only accepted in some cases.
11. On-site customer
There should always be at least one customer available to answer all the questions of
developers and resolve the disputes.
12. Coding Standards
Every programmer should follow the common coding standard so that it becomes easy to
others to review code. It helps in Collective ownership of any piece of code.
21
9.1.4. Phases of Extreme Programming:
1. Planning
In this phase a set of 'user stories' is being created for every features and functionalities that
is to be included in the software. These stories are converted to iterations. And finally,
these iterations are delivered to customers as a fully functioning feature. In this
computerized delivery system, we have conducted meetings between client, developer's
team and stakeholders to create 'user stories' for each feature to be added on the system.
Later, we had divided our project intro smaller sections. For each stories a new release is
launched. There will be an iteration for every story as each story have same flow from
planning to testing phase. Every iteration of our computerized delivery project was started
with planning. And we had made several small releases after each successful completion
of feature.
22
2. Design
XP follows a KIS (Keep it simple) principle. Simple designs are made for the software
including all the features required to be developed in the software. In our computerized
delivery system, we had made our designs simple. It made us easy to analyse the outcomes
of the design. Also, making a simple design saved a lot of time. For this project we had
made designs like Use case Diagram, Entity Relationship Diagram, Class Diagram and
prototype. This helped the developer team to clearly understand the requirements of the
system. (Nayab, 2014)
3. Coding
Developers code according to the metaphors and adopts a collective code ownership.
Coding is made simple to let others review the code. Codes are frequently integrated to the
main repository. In our computerized delivery system, we had made our code simple and
clear so that it saves a huge amount of time. Making code simple helped us in reviewing
other team member's codes. We had set a standard which should be followed by everyone
while coding. Everyone's code had the same standard which help team members to code
collaboratively. We had a paired programming concept where programmers code in a pair.
We would integrate only one pair's code at a time.
4. Testing
In XP, testing is included in the procedure of development phase rather than after the
development phase. In our project of delivery system, we had conducted several unit tests
for each piece of code. We had only released those codes which passes every unit tests.
Testing was done by both developers and clients. When a bug occurs while testing it is sent
to debug and after debugging again tests are made. Only after successful clearance from
all the test it is released.
5. Feedback
Developers take frequent feedback from customers to improve the software and remove
bugs from the software. After every release of a new feature in our computerized delivery
system, we had taken feedbacks from customers. These feedbacks were analysed properly
and changes were made accordingly. No, any feedbacks were neglected in our project.
Every iteration of our project concluded after this feedback stage. This is the final phase of
every iteration.
23
9.1.5. Why chooses XP
XP practices is followed in an effective way for the web applications. XP is feasible to cost and
time than other methodologies. The simplicity of the code helps to highly reduce the amount of
cost and time taken which prevents developers from getting frustrated. Frequent feedbacks from
customer helps developers to improve the software. The breakdown of the project into small
modules and frequent feedbacks allows developers to complete the project on time. Its short
iterative cycles and ability to change according to business needs increases the productivity of the
business in a very high scale. As we had to complete our computerized delivery system on less
amount of time, we have chosen XP because of its time benefits. Also, by choosing this project we
had saved a lot of money and the maintenance of computerized delivery system was easier. As the
coding standards were simpler it was time effective for modifying the previous codes.
9.1.6. Scheduling
25
9.2. Rapid Application Development (Amar Prajapati NP000294)
9.2.1. Introduction
Rapid Application Development is traditional lifecycles developed in 1970s, and still commonly
used which is based on a step-by-step structured approach to system development. Rapid
Application Development is a technique that helps organization to build the important system more
rapidly and strategically while reducing development cost and maintaining quality. RAD helps us
in developing higher quality products in a very short period of time as compared to the traditional
ones. (Iro.umontreal.ca, 2020). RAD doesn't helps us in quickly fixing the one product, which is
probably already late to the marker. Instead, it is a strategic capability which built from the ground
to up. Rapid Application development can be implemented with the four-part strategies listed
below: (McConnell, 2014)
Frequent communication and feedback between the waiter and stakeholders increase the
productivity of delivering and ordering process.
In a shorter time, frame, client get the product delivered.
Faster market analysis.
26
9.2.3. Core Element of RAD:
RAD is a sustainable development model that gives greater emphasis on rapid prototyping and
quick feedback over a lengthy testing and the development cycle. RAD model is very effective if
a customer needs a quick delivery of a product. It is also the best model to choose when
improvements to the prototype will be made throughout the process before completion of the final
product. Rapid Application Development has many cores that make it distinctive methodology,
that are:
Prototyping: A key aspect of RAD is the construction of a prototype for the purpose to
create a feature light version of the finished product in the shortest possible time and to
design a user specification.
Iterative development: Iterative development means the production in short development
life cycles by increasing functional version of the system.
Time boxing: Time boxing can be defined as the process of focusing on accomplishment
of current versions by postponing features for future version of the application.
27
i. Requirements Planning:
Requirement planning phase can be related to a debate on the nature of a project. This planning
phase is streamlined as compared to the other project management methodologies, and this is
a critical step towards the ultimate success of the project. At this stage, developers, a
collaborative meeting is held among developers, customers, and end users to finalize the
project's goal end expectations, as well as current and potential errors that need to be debugged
at construction. It helps in finalizing the specifications with the approval of client and
stakeholders. Such meetings begin the process of development by establishing a mutual
understanding of the goal of the project in general and system in particular. In computerized
delivery tracking system, requirement planning helps to define the requirement of the waiter
and research the current problem in the restaurant for the meal delivery service.
In user design phase, customers and developers work collaboratively to ensure that all the
requirements are met at every step of the design phase. It is almost like interactive system
development which helps to ensure whether the requirements by checking the prototype of the
system at this stage. The user design stage provides a detailed model of the system, a system
design description, and a plan for implementation. End users participated in workshops on
Joint Application Design (JAD) to conduct the research and design activities associated with
this stage (Ftms.edu.my, 2020). The objectives of user design in computerized tracking system
is to develop proposed screen layouts for the home delivery, customer pay and the service
charge and also for preparing a work plan that defines the required steps needed to complete
the food selection of home delivery.
In construction phase, the proposed system is completed and the application software is
developed and tested to implement that design. In this phase, the status of product is determined
and also transition of system is performed. The objective of this phase is to complete the design
including workshop for the system developer. In computerized delivery tracking system, this
phase design, develop and test the software which is prepared to keep record of the waiter and
accept online order from clients.
28
iv. Cutover Phase:
During cutover phase, the new system is constructed, delivered, installed and placed in
operation much sooner. The final phase, the cutover, allow the development team to transfer
the components into a live building environment where all necessary testing or team exercise
can be performed. This phase helps to maximize the effectiveness of restaurant and the
installed system helps to record the information during the customer call, and also accept when
the customer changes their order.
29
9.2.7. Scheduling of RAD:
30
9.3. Rational Unified Process (Pallavi Kumari Sah NP000319)
9.3.1. Introduction
The Rational Unified Process is one of the Software Development Process. It offers a disciplined
approach within an organization to delegate roles and responsibilities. The goal of Rational Unified
Process is to ensure the production of high-quality software in a consistent schedule and within
budget which meets the needs of its end users. RUP provides best practices to each member of the
team with proper guidelines and templated. Rational Unified Process focus more on the
maintenance and development of the product rather than production of large quantities of paper
documents. (Ibm.com, 2020)
Rational Unified Process is declared as a set of best practices within this Computerized Delivery
tracking system what I seem to be a pattern procedure for the development of complex and large
system. Some of the benefits are listed below as Why RUP is suitable for Computerized Delivery
Tracking System?
RUP offers better control over the computerized delivery tracking system.
It leverages team productivity by providing the guidelines and tool mentors within the
computer delivery tracking system.
Unifying software within a computerized delivery tracking system.
Efficient delivery process.
Control changes within the restaurant. (ActiveCollab, 2020)
31
9.3.3. Phases of Rational Unified Process:
1. Inception Phase:
In the inception phase, overall cost and the time schedule for Computerized delivery tracking
system is estimated. The initial evaluation is conducted during this phase to determine the scope
of the system by gathering the restaurant member and discuss whether the computerized tracking
system is worth pursuing or not, what is intended to be in the product and what is not, and also
prepare the supporting environment for the project. (Ftms.edu.my, 2020)
2. Elaboration Phase
In the Elaboration phase, stability of the design is fixed, analyze requirements, develop plan for
the system and eliminate highest risk element of computerized delivery tracking system.
Depending on the constraints i.e. scope and size of the computerized delivery tracking system, an
executable design of the system is built based on one or more iterations. (Ftms.edu.my, 2020)
32
3. Construction phase:
In the construction phase, the coding, testing and implementation for computerized delivery
tracking system is completed. In this phase, all the components and application of the workable
system are created and integrated into product, and then thoroughly tested. In the process, RUP
achieves adequate quality as rapidly as possible and minimize development cost through
optimization of resources to achieve degree of parallelism in the work of development teams of
the restaurants. (Cscjournals.org, 2020)
4. Transition Phase:
When the system is ready to be deployed in the customer environment, the transition phase is
designed. In the transition phase, the system is deployed within the features of computerized
delivery tracking system. It focuses primarily on the activities needed by the users to place the
delivery tracking system in market. This process involves multiple revisions, as well as updates of
bug fixes and many improvements. The main goal of this process is to achieve user self-
sufficiency. (Cscjournals.org, 2020)
33
every week, weekly sales report. And also keep the record when a customer places an order
either through telephone or through the company website.
Visually Model Software: The Rational Unified Process provides graphical representation
for visualizing the object of the computerized delivery tracking system, based on Unified
Modeling Language.
Verify Quality of Software: Quality should be evaluated on the basis of authenticity,
capabilities, features and performance of the system.
Control Changes to Software: Describes how to control, track and monitor all the forms of
changes to enable successful iterative development which will inevitably occur throughout
the development of the computerized delivery tracking system. (Ibm.com, 2020)
34
9.3.7. Project Scheduling of RUP:
35
Figure 18: Timeline Scheduling of RUP
36
10. Conclusion:
In this project, Computerized Delivery Tracking System is developed to solve the existing
problem. For this, various agile methodologies are considered to go through the various phases of
system development by our company for achieving the goal of project. System Development
Methodology is flexible and user-friendly methodology which helps to successfully implement
changes in any organization. The methodologies i.e. Rapid application development, Rational
unified process and Extreme programming chosen for this system provide support to both
development team as well as customers.
While doing this project, we came to know about different information system development
methodologies and also many ideas about web-based application. In this project, online delivery
tracking system is designed which helps customers to easily place an order of their choices. This
project has instructed us to work in team and work on genuine field. By agile principles, the
methods are carried out for better customer satisfaction and requirement fulfillment. The overall
stages of a system development are fulfilled in a sequential manner.
37
References:
1. ActiveCollab. (2020). Rational Unified Process (RUP) · ActiveCollab Blog. [online]
Available at: https://activecollab.com/blog/project-management/rational-unified-process-
rup
3. Beck, K. and Andres, C. (2005). Extreme programming explained. 2nd ed. Boston: John
Wait.
4. Cscjournals.org. (2020). [online] Available at:
https://www.cscjournals.org/manuscript/Journals/IJSE/Volume5/Issue2/IJSE-142.pdf
[Accessed 8 Jan. 2020].
5. Dudziak, T. (2000). eXtreme Programming An Overview. Methoden und Werkzeuge der
Softwareproduktion WS 1999/2000. Available at
http://csis.pace.edu/~marchese/CS616/Agile/XP/XP_Overview.pdf
[Accessed 8 December 2019]
38
8. Ftms.edu.my. (2020). [online] Available at:
http://www.ftms.edu.my/images/Document/IMM006%20-
%20RAPID%20APPLICATION%20DEVELOPMENT/Chapter%202nnote.pdf
[Accessed 7 Jan. 2020].
9. Ibm.com. (2020). [online] Available at:
https://www.ibm.com/developerworks/rational/library/content/03July/1000/1251/1251_b
estpractices_TP026B.pdf
[Accessed 8 Jan. 2020].
10. J.Choudhari and Dr. U.Suman, Iterative Maintenance Life cycle using Extreme
Programming, in International Conference on Advances in Recent Technologies in
Communication and Computing in 2010
39
17. McConnell, S. (2014). Rapid development. Redmond (Washington): Microsoft Press.
18. Soliant. (2020). Rapid Application Development: A Guide from Top Developers. [online]
Available at:
https://www.soliantconsulting.com/blog/rapid-application-development/
40
Appendices:
Work Load Matrix
Chapters Aaditya Jha Amar Prajapati Pallavi Kumari Shah
(NP000290) (NP000294) (NP000319)
Introduction ✓ ✘ ✘
Agile Principle ✘ ✘ ✓
IS methodologies ✘ ✘ ✓
System Analysis ✓ ✘ ✘
System Design ✘ ✓ ✘
Testing ✘ ✓ ✓
System Deployment ✓ ✘ ✘
41