Chapter 10
Chapter 10
Chapter 10
Chapter 10
Learning Objectives
By reading and completing the activities in this chapter, you will be able to:
Chapter Outline
Focusing Story: The $6 Billion Software Bug
Time, Cost, and Quality
Software Development Methodologies
Learning Activity 10,4*Determining Requirements
Traditional Systems Development Life Cycle
Learning Activity. 10.2: Advantages and Disadvantages of the SDLC
Alternative Methodologies
Learning Activity 10.3: Developing by Modeling
Learning Activity 10.4: Comparing the Methods
Build or Buy Decision
Learning Activity 10.5: App Developers Needed!
Using Open Source Software in Business
Learning Activity 10.6: How Open Source Software Impacts Build versus Buy
Outsourcing Information Systems
Learning Activity 10.7: What to Outsource
In this chapter, you will gain a basic understanding of the software development process. In addition, the chapter will help
you learn about alternatives to building software from scratch. Outsourcing information systems is also discussed.
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
FOCUSING STORY
+ In February 2020, hundreds of flights were disrupted at Heathrow airport in London, UK, when a technical issue
made the check-in systems and departure boards defective.
+ In July 2019, Facebook users were unable to upload photos to their news feed, see stories on their Instagram
account, or use WhatsApp to send messages because of a software glitch that was accidentally generated when the
company performed routine maintenance on software.
+ In April 2018, a UK bank called TSB was planning to close Internet and mobile banking services for a weekend to
perform a system upgrade. However, when the new system.was switched on, millions of customers could not
access their accounts for up to two weeks.
* In 2017, Dodge Ram recalled 1.25 million Ram trucks because of a software glitch that caused the airbags and
seatbelts to fail during a rollover accident.
* In 2017, a major software failure at British Airways caused a significant number of local flights to be canceled and
several delays to international flights.
Sources: Computerworld UK Staff. 2020" “Top Software Failures in Recent History.” Computerworld, February 17.
https://www.computerworld.com/article/3412197/top-software-failures-in-recent-history.html.
Focusing Questions
1. Have you ever experienced software that did not operate correctly? What consequences did you experience?
2. What can be done to'limit software errors?
3. Why is it important to catch software errors early in the development process?
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
Some versions of the triangle substitute scope (what is done as part of the project) for quality. Scope and quality are
closely related, especially when considering an overall project. Quality is related to user requirements, and increasing the
scope of a software development project adds new requirements that need to be met. So increasing the scope of a project
also makes it harder (more costly and/or longer in duration) to meet quality goals.
There is an old saying: “You want it fast, good, and cheap? Pick any two.” Increase the speed with which a project is
delivered and you will have to compromise on either quality or costs. Decreasing the cost requires a longer completion
time or accepting lower quality. It is important to understand these trade-offs when making software development
decisions. Typically, one of the three constraints is fixed (for example, you may have a strict budget or delivery date). As a
result, the other two constraints must be managed against each other. For example, if you have a fixed budget, moving to
an earlier delivery date requires changes in quality or scope. You can learn more about this in relation to project
management in Appendices J and K on funding and managing projects.
project may follow a different methodology than a transaction processing system (TPS) development project.
Determining Requirements
Determining system requirements is a major step in the software development process. One method for uncovering
requirements is to interview the intended users of the software. Suppose that a club you belong to wants to create a
system for keeping track of members. Get in pairs. One of you will act as the interviewer who is trying to discover
requirements. The other will act as the user. Document at least 10 requirements for the system.
The main reason to use a formal software development methodology is that it provides discipline by clearly defining
how the project should proceed, what work should be done, how that work should be done, and what outputs should be
produced. Having a standard methodology in an organization also allows individuals to more easily join a project in
progress. The standardized roles, processes, documentation, and deliverables make it easier for a new team member to
become familiar with what has been done on the project. It also makes it easier for the new member to find relevant
information.
the results of one phase flow as inputs into the next phase. It is important to realize that there are many different versions
of the “traditional” SDLC. The differences boil down to how the phases are divided; some versions have more phases than
others. The versions with fewer phases collapse multiple phases from the more complex versions into a single phase. In
this chapter, we present a relatively typical version with six phases, as shown in Figure 10.1. Note the dashed feedback
lines on the left-hand side of the diagram. Sometimes you need to go back and refine an earlier phase based on new
information that emerges.
Planning Phase
The goal of the planning stage 15 to define the overall goal and scope of the system and determine the feasibility of the
project. Essentially, you want to answer the question “Why build the system?” In addition, you need to establish whether
the project is feasible. There are several different aspects to feasibility:
* Technical feasibility concerns whether the proposed system can be completed from a technical standpoint. It is
important to consider whether the system fits with the existing technical infrastructure.
* Economic feasibility relates to whether the proposed system is affordable and worth the investment.
* Organizational feasibility concerns whether the project fits with the organization’s existing strategies and
practices. If the system does not fit with current ways of operating, the organization needs to determine what
needs to be changed and whether these changes are feasible. Organizational feasibility should also consider
whether the organization has access to the human resources necessary to complete the project.
* Legal feasibility concerns whether the proposed project violates any laws or regulations.
* Ethical feasibility considers whether the system fits within the ethical guidelines and practices of the
organization and its industry.
The major deliverables of the planning phase are the feasibility analysis, project initiation document, and the project
management plan. The project initiation document specifies the high-level goals of the system and describes the business
case for the system. (A business case describes the system and why it is needed.) The feasibility analysis results are often
included in the business case. The project management plan documents the scope of the project, identifies major tasks and
resources, and describes any interrelationships with other projects.
Requirements Phase
The goal of the requirements phase is to uncover and document the functions that the system should provide and desired
levels of performance. In other words, in the requirements phase, the task is to figure out and document what the system
should
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
do. There are two types of requirements: functional and nonfunctional. Functional requirements describe how the
system should interact with users and other systems. An example of a functional requirement is “The system shall allow
customers to look up the price of a product.” Nonfunctional requirements are related to constraints on the system—for
example, how well it should perform. An example of a nonfunctional requirement is “The system shall be available at
least 23 hours per day.”
Requirements elicitation involves gathering requirements from various stakeholders and is a primary task in the
requirements phase. Gathering the requirements for a system is often a difficult, time-consuming, and error-prone process.
To make things worse, requirements may change during the process. Despite the difficulties, it is very important to fully
understand the system’s requirements; they form the foundation for the rest of the development project.
The output of the requirements phase is a specification of the system’s functional and nonfunctional requirements.
Typically, this takes the form of a set of requirements statements (sometimes called system shall statements) or a set of use
cases, in either text or diagram form. A system shall statement simply defines a requirement, such as “The system shall
allow teachers to enter student grades.” A use case describes a sequence of actions that results in an outcome for some
actor. An actor can be a user or another external system. Figure 10.2 shows a«use case diagram. (Use case diagrams are
part of the Unified Modeling Language, which was developed as a standard way to specify models related to software
systems.)
It is important to understand that requirements should specify what the system must do but not how the system should
meet the requirements. This allows the system designers flexibility in the design of the system, which is covered in the
next phase.
Student
Design Phase
The main goal of the design phase is to describe in detail how the system will meet the requirements specified earlier. The
requirements form the foundation of the system design. The focus here is on how the system will satisfy the requirements,
although there are elements of the design phase that still deal with what the system is intended to do. These elements are
known as the logical system design, which includes abstract models of what the system is intended to do. An example of
such a model is the database diagram we saw in Chapter 5 (Figure 5.4). In addition to the database model, the user
interface and business rules enforced by the system need to be designed. The design phase also specifies the plans for
implementing and testing the system. The system design document is a major deliverable of the design phase. This
document describes, in detail, the system requirements, operating environment, database design, user interface, and
processing logic. Other deliverables include an implementation plan and a training plan.
Development Phase
During the development phase, the outputs of the design phase are converted into the actual information system. This is
the phase in which the system is actually constructed. The software is written, databases are created, and any necessary
hardware is installed. It is often necessary to integrate the new system-with existing information systems; if needed, the
integration occurs during the development phase. System testing is a eritical part of the development phase. Testing occurs
both during the development of the software and when the entire system is complete and integrated. Software testing is a
complex, time-consuming, but critical aspect of systems development. It is necessary to thoroughly test the system prior
to actual implementation. Errors are very expensive to correct when they are not discovered until after the system is
implemented. The errors may also lead to business disruptions. The development phase’s deliverables include the
application software, data and files for testing, and documentation on how the software components interact with one
another and external systems.
Implementation Phase
The goal of the implementation phasé is to make the system operational in a production environment. One important
implementation phase activity is_to notify users of the rollout of the new system. This notification should include the
implementation schedule, differences in work processes and responsibilities brought about by the new system, and the
process for obtaining technical support for the new system. User training is also an important activity in this phase. Often,
it is also necessary to convert data from the existing system into the new system. For example, a new product cataloguing
system might need to have data from the old system migrated into the new system. Finally, it is a good practice to have a
postimplementation review that documents the project to date and makes recommendations for improvements for future
projects. The main deliverable of the implementation phase is the system
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
itself, installed and running correctly. The postimplementation review report is another deliverable from this phase.
There are four common approaches to system migration:
* Direct changeover (also called immediate changeover): At a specific point in time, the old system is no longer
used and is replaced by the new system. While this has the advantage of being rapid, it is very risky. If the new
system has problems, the functions available in the old system are also unavailable.
* Parallel operation: Both the old and new systems operate for some period of time. The parallel approach is less
risky than direct changeover but also takes longer and is more expensive. The parallel approach is necessary for
systems that cannot be taken out of service while changing from the old to the new system.
* Phased implementation: The new system is implemented in stages. This approach is an attractive compromise
between direct and parallel approaches. However, it is best suited for systems that have clear modules that can
be implemented in a phased manner. Systems with significant interdependencies between modules are not
suitable for phased implementation.
* Pilot operation: The new system is implemented in a business unit (such as a store or department) or location
(such as a state or country). The initial pilot is followed by other pilot changeovers ora full changeover to the
new system. Each pilot changeover must use one of the other approaches.
Maintenance Phase
The final phase in the SDLC is the maintenance phase. This is usually the longest, most costly phase of the life cycle. It is
not unusual for more than half of the total system cost to occur in the maintenance phase. The goal of this phase is
ensuring that the system operates properly to meet current needs. This involves fixing any problems that are uncovered
and may also involve modifying or adding to the programs to meet new needs. In addition, the system may be modified to
improve performance or take advantage of new technologies. For example, an online ordering system may be modified to
allow customers to order from their smartphones.
Although we presented the SDLC as a very linear process, where one phase follows the next in an orderly fashion,
reality is rarely so neat. During the systems development process, it is often necessary to revisit an earlier phase when new
needs arise or problems are discovered.
As you will discover in Learning Activity 10.2, there are advantages and disadvantages to the traditional SDLC. These
drawbacks led to the development of alternative methodologies. In the next seetion, we describe several of these
alternative approaches. .
s ¥ - 1
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
Alternative Methodologies
Prototyping
Prototyping is an approach to deal with aspects of a full methodology; it is not a complete, stand-alone methodology. In a
prototyping approach to systems development, you begin with an initial investigation of the main requirements of the
system. It is not necessary to have a full understanding of all requirements. After the initial investigation, a small-scale
mock-up of the system (called the prototype) is built and reviewed by stakeholders. The stakeholders point out flaws,
which reveals new or misunderstood requirements. The prototype is refined and reviewed. This cycle repeats until the
stakeholders are satisfied that all requirements are met. Then the full system is implemented. Some prototypes are
“throwaway” prototypes, which means that they are not intended to be part of the final system; their purpose is to uncover
requirements and problems. Sometimes, however, prototypes become part of the final system. This is known as
evolutionary prototyping.
Increased stakeholder involvement is a major benefit of the prototyping approach. The stakeholders know the particular
business area addressed by a system much better than the systems developers and having, them involved throughout the
development process can lead to systems that better meet their needs. In addition, stakeholder involvement may increase
satisfaction with the final system. Prototyping is also potentially more effective for uncovering system requirements. This
is especially important when requirements are unclear, ambiguous, or difficult to define. In some cases, a prototyping
approach may be less expensive than 4 traditional SDLC approach.
There are also drawbacks to the prototyping approach. Prototyping can lead to poorly designed systems that do not
perform well when scaled up for actual use. It is also difficult to estimate how many iterations are required, which makes
it difficult to estimate costs and schedules. Usually, prototyping results in less-well-documented systems, which may
cause problems later (for.example, when the system needs to be revised or integrated with new systems). Finally,
nonfunctional requirements (such as performance requirements) are difficult to establish using prototypes.
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
* In March 2015, a German basketball team had to start a game 17 minutes late because the computer connected
to the scoreboard started an automatic Windows update. As a result, the delayed game meant that the winning
team actually lost and was thus relegated to a lower division.
* In 2015, Target closed its operations in Canada after an attempt to implement SAP throughout its stores failed
and the resulting supply chain issues left shelves empty. When the 133 Canadian stores were closed, 17,600
employees lost their jobs.
* In August 2016, Australians were unable to complete their census on their désignated day because the online
system failed.
* In August 2018, 400 homeowners found that their mortgages from Wells Fargo were foreclosed accidentally
because of a calculation error in the accounting software the company was using.
* In March 2018, a self-driving car from Uber Technology made a wrong decision about “an object” and ended
up killing a pedestrian in Phoenix, Arizona.
While these failures and those presented in the focusing story mostly show bigger businesses, software and project
failures affect all types of organizations worldwide, including many governmental agencies. The Consortium for
Software Quality estimated that in 2018, the cost of poor quality software in the United States was approximately
$2.26 trillion, composed of losses from software failures (37.46%), issues with legacy systems (21.42%), finding and
fixing defects (16.87%), and troubled or canceled projects (6.01%). The remaining 18.22% is assigned to what they
call technical debt, which refers to what is the estimated cost of fixing problems still in the software code. Another
study suggests that in 2016 companies had to spend on average $97 million to resolve failures for every $1 billion they
invested in IT projects (Florentine 2017). Why do projects fail? In some cases, the“initial estimates of the costs,
resources, and delivery date are unrealistic. Other causes include misunderstanding requirements, “feature creep”
(expanding requirements), and inadequate testing.
Sources: Florentine, S. 2017. “IT Project/Success Rates Finally Improving.” CIO Magazine, February 27.
https://www.cio.com/article/3174516/it-project-success-rates-finally-improving.html; Krasner, H. 2018. The Cost of Poor Quality
Software in the US: A 2018 ReportConsortium for IT Software Quality, September 26. https://www.it-cisq.org/the-cost-of-poor-
quality-software-in-the-us-a-2018-report/ The-Cost-of-Poor-Quality-Software-in-the-US-2018-Report.pdf; Hamrouni, W. 2017. “5
of the Biggest Information Technology Failures and Scares.” Exo, August 1. https://www.exoplatform.com/blog/2017/08/01/5-of-
the-biggest-information-teghfiglogy-failures-and-scares/; Head, B., and D. Walker 2016. “The Enormous Cost of IT Project
Failure.” In the Black, Nevember 1. https://www.intheblack.com/articles/2016/11/01/enormous-cost-it-project-failure,
Prototyping is best for systems that require extensive user interaction and for which the analysts have some
understanding of the business issues to be addressed,
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
especially when functional requirements are not well understood. Prototyping is less well suited for systems that have
well-defined requirements, when nonfunctional requirements are especially important, or when future scalability is
important.
Developing by Modeling
Systems development can be very labor intensive for large scale organizational applications. However, today’s new
easy-to-use development modelers allow even those with basic development knowledge to create their own
applications. In this learning activity, you will use the Mendix (www.mendix.com) modeler to create an app assigned
by your instructor.
1. Watch the tutorial (https://docs.mendix.com/howto/tutorials/) for the type of app your instructor has assigned.
2. Register with your EDU account (to obtain free access) at https:/signup.mendix.com/link/signup/.
3. Develop your assigned app.
lower quality software. Because users often want more and more features, “feature creep” may be more likely with RAD.
Since there is less focus on nonfunctional requirements, systems may not perform well when scaled to more users or
greater volumes of processing.
RAD is best suited for smaller-scale projects with well-foctsed organizational objectives and committed users. RAD
does not work as well for very large projects or systems where performance and quality are critical. For example, you
might not want to use RAD for a safety-critical systemisuch as an air traffic control system.
DevOps
DevOps is an approach to software development that focuses on rapid development of applications and services. The idea
is to rapidly build, test, and release software products while continuously monitoring the released software. Figure 10.4
shows the main elements of DevOps. It is called DevOps (Development-Operations) because the operations of the
software are no longer separated from the development of the software as in traditional approaches.
The success of DevOps in recent years is based on several principles, such as delivering frequent but small updates to
the software (continuous delivery), breaking large projects into smaller projects (this is also called microservices—
building a set of small services to build an application), and, importantly, the concept of continuous integration.
Continuous integration is when developers place their newly developed code or changes to code into a central repository
where tests are run to more quickly identify possible software errors. It is also very important to note the role of logging
and monitoring of the released software. As part of DevOps, companies constantly collect data about the software’s
performance and analyze and log those
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
data so they can better understand how any changes to the software are affecting its users. The benefits of DevOps are
numerous. First, because employees working within operations and within the development enterprise are jointly involved
in the development, operations, and monitoring of the software, companies experience better collaboration and
communication. Of course, the goals of DevOps being speed of development and rapid delivery are also benefits. In
addition, many argue that DevOps leads to more reliable and secure software.
In a 2019 report on DevOps by Dora and Google Cloud (https://services.google.com/fh/files/misc/state-of-devops-
2019.pdf), it is suggested that there are four key metrics to measure the performance of a company’s DevOps usage:
deployment frequency, lead time for changes, time to restore service, and change failure rate. The report suggests that the
best “elite” DevOps performers are able to deploy on-demand services with multiple “deploys” per day, that it takes less
than a day to go from code that is ready for deployment to actual deployment, that it takes less than one hour to restore
service after an incident such as an outage, and that less than 15% of the changes that are released result in lower service.
This is just a sampling of some of the more common systems development methodologies. There are many others.
Several of these fall into the category of agile development methodologies. Agile development occurs in self-managed,
cross-functional teams whose members include information systems professionals and user representatives. Rather than
being process oriented, agile methods are people oriented. Agile methods emphasize multiple iterations and continuous
feedback from user representatives. Many specific methodologies fall into the family of agile methods. These include
extreme programming (XP), which uses frequent releases with short development cycles, and Scrum, which features work
“sprints” of one to several weeks, at the end of which the development team meets with stakeholders to assess progress
and plan what needs to be done next. Another approach is called the Spiral Model, which is like an iterative SDLC that
focuses on identifying and reducing risks when developing critical systems. As software and
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
its uses continue to evolve, we expect that software development methodologies will do the same.
deploy
monitor
LEARNING ACTIVITY{IOA
7 4
Comparing the Methods
Pick one of the alternative software development methufifi:gies described in the chapter. Compare it with the
traditional SDLC. Find at least three ways they are similar and three ways they are different. Be prepared to share your
answers. A
As you can see, there are many different methods for developing systems; choosing the, correct methodology depends
on many factors. However, developing a system from scratch is not the only option available when an organization needs
a new system. It may be preferable to buyrather than build the system. This choice is the topic of the next section.
for support, including enhancements and fixes. In addition, a financially weak vendor may be unable to provide proper
support or maintenance. In extreme cases, the vendor may go out of business.
Hybrid solutions may use components from different vendors to create the complete solution or may involve
customizing COTS software by modifying programming code or adding small programs called scripts. In ideal cases, the
hybrid solutions offer the best of custom and COTS approaches. The hybrid solutions usually better fit business
requirements and existing processes but can be delivered less expensively and more quickly than custom solutions.
However, hybrid solutions also suffer from some of the same drawbacks as custom-built systems and COTS solutions. In
addition, it may be difficult to find the expertise necessary to modify or combine the COTS components. Figure 10.5
provides an overview of some of the characteristics of the three approaches.
Degree of customization
Figure 10.5 Comparing COTS and Custom Development Source: Adapted from
http://www.baselinemag.com/c/a/Application-Development/Buy-vs-Build-Software-Applications-The-Eternal-Dilemma.
When making the build versus buy decision, a number of questions must be addressed:
« Is there COTS software that will meet the business’s needs? If the answer to this question is no, your choices are
narrowed to custom development or a hybrid approach. If no COTS software can meet your organization’s
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
needs, you have to create the software or customize COTS software. In these cases, you may have the option of
outsourcing the development or customization. (We discuss outsourcing later in this chapter.)
* Will the software give your company a competitive advantage? If COTS software is an option, the next question is to
consider whether the system will give your company a competitive advantage. If so, the scale is tipped toward building
custom software. If not, COTS software may be a better choice. To understand why, think about the example of a hotel
chain. To such a company, a payroll system would not be likely to provide any competitive advantage. Payroll is a routine
function, so it is a good candidate for COTS software. In contrast, having a custom system for analyzing the behaviors
and preferences of frequent guests may give the company an advantage over its competitors and is therefore a better
candidate for a custom-built system.
* Does the COTS software fit with business processes? COTS software will rarely match exactly with existing business
processes. As a result, you will usually have to modify at least some business processes to use COTS software. Often, this
is not a problem, but sometimes the changes necessary are so extensive that it may be better to build a custom system. The
key issue is whether it is practical to alter existing processes to fit the way the COTS software operates.
* Does the COTS software fit with existing IT architecture and staff? To be‘successful, COTS software must fit with your
organization’s existing IT. Here is a simplistic example. Suppose that your organization used only Windows-based PCs.
Macintosh-only COTS software would not be a good fit with your existing IT. It is also important that your IT staff be
able to support any COTS software you use. If the existing staff cannot provide support, you will need to either contract
with an outside company for support, train your existing staff, or hire new staff. All of these add to the cost and
complexity of implementing the COTS software.
* Do you have the capability to create the required system? There are times when an organization simply does not have
the capability to create a system that meets requirements. In these cases, COTS software is often an attractive option.
Outsourcing the development of the system is another, option.
* When is the system needed? A COTS solution can almost always be implemented faster than a custom-built system. As
aresult, you should consider the “go-live” goal for the new system when making the build versus buy decision.
* What is the total cost of ownership for each approach? Finally, you should compare the total cost of ownership (TCO)
for both approaches. The cost of purchasing or building the system is not the only cost you should consider. There are also
support and maintenance costs, costs to integrate
PRINTED BY: Moses Maenetje ([email protected]). Printing s for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
the system into the existing architecture, and costs related to enhancing the system in the future. One important point to
keep in mind is that COTS systems usually are changed much more often than custom-built systems. When the vendor
releases a new version of the software, you may incur additional costs related to deploying the new version. Of course,
you could stay with the old version, but vendors often drop support for older versions, which may lead to problems.
Why would businesses use open source software? There are a variety of reasons. The most obvious is the potential cost
savings. Most open source software can be acquired without charge. It is important to note that this does not mean that the
software can be implemented without cost. There are ongoing costs associated with installation, support, and continuous
training; these costs should not be ignored. Another reason businesses use open source software is to avoid being
dependent on proprietary software vendors for ongoing development and support. For example, users of Microsoft Office
are completely reliant on Microsoft for current developments (such as fixing errors or enhancing the software). With open
source software, the larger community can carry out these functions. This means that continuous development and support
are possible even if the creator of the software goes out of business. There is also some evidence that mature open source
software is often more reliable than proprietary software. In addition, open source software is more likely to use open
standards for things such as file formats. This reduces the reliance on any particular software vendor. Additional flexibility
comes from the fact that users have the ability to modify the software as needed. This is not possible with proprietary
software. (It should be noted that most users lack the technical skills necessary to modify software, which reduces the
value of this benefit.)
One interesting aspect of open source software is that a community of volunteer programmers often does ongoing
development. The structure of an open source development community is like an onion. Core developers are at the center,
and passive users are at the outermost layer. The core developers do most of the programming for both the original
creation and ongoing development. Developers at outer layers report errors and request features and may also contribute
fixes for the errors. Active users also report problems but do not contribute any programming code, and they often help
less experienced users in community forums. Thus the community not only supports current users but also provides a
platform for ongoing enhancements.
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
Outsourcing Models
There are many different outsourcing models. These differ in the degree of outsourcing and in what is outsourced. Some
organizations contract with a service provider to provide all IT-related services. This is known as full or complete
outsourcing. Full outsourcing allows an organization to focus on its core activities and may also reduce IT costs. Service
providers may be able to provide services less expensively because of economies of scale.
In contrast, in selective or partial outsourcing, only certain aspects of IT are outsourced to a service provider. For
example, AT&T at one point outsourced the maintenance of its ERP system to Accenture. There are different approaches
to deciding what to outsource. Under process-based outsourcing, an organization outsources a particular function or
business process. Functions that are often outsourced include help desk support, payroll and benefits processing, and
telecommunication services. Outsourcing specific functions is not new. For example, ADP (adp.com) has been providing
payroll services to organizations for more than 70 years.
Personnel outsourcing is another form of outsourcing that has a long history. This form of outsourcing allows
organizations to meet staffing needs without the long-term costs associated with hiring permanent workers. Bringing in
temporary,
PRINTED BY: Moses Maenetje ([email protected]). Printing s for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
contract-based workers may be effective when an organization needs specific expertise on a short-term basis or when the
current workload is more than the internal IT staff can handle. In these cases, outsourcing can speed time to deployment
for a system and avoid costs related to training the current staff.
‘What to Outsource
Outsourcing occurs when a company turns to an outside vendor to provide some service. While the definition of
outsourcing is easy to understand, deciding what to outsource is much harder. For each of the following business
scenarios, decide whether the system or operation should be outsourced. Explain your answers.
Organization System/Function
Another approach is project-based outsourcing. As/the name implies, this involves contracting with a vendor for a
specific project. Since projects have specific start and end points, when the project is finished, the outsourcing
engagement ends. Organizations outsource projects when they lack the internal resources necessary to complete the
project. Earlier we mentioned outsourcing as an‘alternative for developing a custom system. This is an example of project-
based outsourcing. When the system is developed and deployed, the outsourcing engagement ends. Interestingly, upgrades
to the system may lead to future outsourcing engagements.
Application outsourcing involves aservice provider handling activities related to a specific software application for a
fee. There are different forms of application outsourcing. With application hosting, the client organization is responsible
for operating the IT infrastructure associated with the application, but the client must purchase the software and pay any
annual license or maintenance payments to the software publisher, Amazon’s Web Services is an example of application
hosting. Organizations can deploy applications on Amazon’s systems. Amazon handles keeping the servers up and running
but is not responsible for maintaining the application. This arrangement is often very cost effective, especially when there
are demand spikes that may require additional server capacity. Software as a service (SaaS) provides on-demand Web-
based access to an application on a per-use or per-user basis. Salesforce.com is a well-known provider of SaaS.
Salesforce.com provides organizations with customer relationship management software for a monthly per-user fee.
Different features lead to different fees. For example, Salesforce pricing for Customer Relationship Management
(discussed in Chapter 12) in 2020 varied from $25 to $300 per user per month depending on the desired level of service.
The SaaS model provides a large degree of flexibility and can be cost effective. The client organization does not have to
worry about maintaining the software or the servers. SaaS also provides very good scalability. However, there are security
and privacy concerns with SaaS.
rapid delivery of projects through additional expertise and personnel and can be an effective means of managing capacity.
It is generally easier to contract for additional capacity than to add it through other means. Selective outsourcing allows
management to focus on core
PRINTED BY: Moses Maenetje ([email protected]). Printing s for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
business activities. Finally, when outsourcing sites are spread across time zones, offshore outsourcing can lead to 24-hour
productivity.
There are also risks associated with outsourcing. In some cases, outsourcing can lead to a loss of competencies within
the organization. This is especially problematic when this loss is related to the core activities of the organization. There
are also risks related to the outsourcing relationship. There is a risk of becoming dependent on the service provider, which
can lower bargaining power in later negotiations. In addition, there is a danger that the vendor may behave
opportunistically and take-advantage of the organization’s lack of expertise or inadequate monitoring. Risks from
opportunism are especially high when the outsourcing contract is not well structured. Outsourcing may also hurt the
morale of the remaining workforce. Finally, there are risks related to confidentiality. Outsourcing vendors must ensure that
sensitive information.is properly protected. This is both a technical and human
PRINTED BY: Moses Maenetje ([email protected]). Printing s for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
problem. Even when the proper technical security measures are in place, the employees of the service provider can
compromise confidentiality. The benefits and risks of outsourcing are summarized in Table 10.1.
* How mature is the IT system in question? Systems that have been around a long time are better candidates for
outsourcing. There are several reasons for this. First, if the system is mature, organizations are less likely to be
able to gain a competitive advantage from the system. Second, it is easier to find competent vendors for mature
systems. This also means that organizations are more likely to have a choice of vendors, which is helpful during
negotiations, both initially and in the future.
* How significant is the system to the organization’s competitive advantage? One common reason for outsourcing
is to allow the organization to concentrate on core activities, Qutsourcing is more suitable for systems that do
not provide a competitive advantage. There is also a greater risk of loss of control when you outsource strategic
systems; problems with strategic systems usually have serious consequences.
* How does the organization’s IT capability compare with that of its competitors? In cases where an organization
has relatively weak IT capabilities, it may be better to outsource. This is particularly true if the organization is
weak in IT related to the system in question.
* Are there cost advantages to outsourcing? Of course, the question of costs is also important. Even if there are no
savings through outsourcing, it may still be a good idea if outsourcing allows the organization to focus on
critical areas or if the organization lacks the necessary capabilities.
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
Geographic Considerations
Where to outsource is an important aspect of outsourcing. (Note that choosing a vendor is also important, but here we
focus on location.) Offshore outsourcing involves using a vendor that provides services from a location outside the client
organization’s region. A U.S. computer manufacturer outsourcing technical support to India is an example of offshore
outsourcing. This is often done to reduce costs. Developing countries have much lower wages than developed countries,
so offshore outsourcing can be very cost effective. However, there may be a backlash to offshore outsourcing. This can
result from customers being upset about jobs sent overseas. Resistance can also come from poor language skills or
cultural differences. Language and cultural differences, along with distance, can make offshore outsourcing arrangements
difficult to manage.
Nearshore outsourcing is similar to offshore outsourcing. The difference is that nearshore outsourcing occurs close to
the client’s home location. If a U.S. company outsources to a Canadian firm, this would be a nearshore arrangement. The
reduced travel times may make management easier. Cultural and language differences may be reduced, but this is not
always the case. A U.S. company outsourcing to Mexico may still face considerable language and cultural barriers. A
nearshore arrangement often results when a company wants to gain some of the cost savings of offshore outsourcing while
reducing some of the management, language, and cultural difficulties.
Onshore outsourcing is outsourcing to a firm located in the same country. Onshore outsourcing may offer significant
cost savings while eliminating the cultural and language barriers of offshore outsourcing. In addition, onshore outsourcing
is less likely to bring about a customer backlash, since the jobs-are staying in the country. Cost savings result from
differences in wage rates for different areas of a country. Wages in rural areas are often considerably lower than in urban
areas. As a result, rural onshore outsourcing saves significant money over urban areas and is only slightly more expensive
than offshore outsourcing.
Chapter Summary
In this chapter, we discussed various approaches to developing information sys[emg. We began by describing the time,
cost, and quality trade-off. Then we talked about different software development methodologies, including the traditional
systems development life cycle and its alternatives. We also discussed the build or buy decision and advantages and
disadvantages of using open source software. The chapter concluded with'a discussion of outsourcing. Here are the main
points discussed in the chapter:
* Software development methodologies provide discipline to the development process by defining processes,
roles, and deliverables. \
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
* The traditional systems development life cycle (SDLC) is a semisequential, phased approach. There are different
versions of the traditional SDLC.
« *The SDLC described in this chapter consists of six phases: planning, requirements, design, development,
implementation, and maintenance.
« *Alternatives to the traditional SDLC include prototyping, rapid application development, and DevOps, as well as other
agile methodologies.
» * The decision of whether to build custom software or purchase commercial, off-the-shelf software is complex.
« * Open source software allows users to access the underlying source code for the application, which allows users to
modify the program.
« +Open source software is usually free, although some companies charge a fee for ongoing support.
« * Outsourcing occurs when an outside organization provides IT services that were previously provided internally.
« * Outsourcing models include full (complete), process-based, personnel, project-based, and application outsourcing.
« * There are both benefits and risks associated with outsourcing.
» * Factors affecting the outsourcing decision include the maturity of the system, the system’s significance to the
organization’s competitive advantage, the organization’s IT capability, and cost.
« + Offshore outsourcing occurs when an organization receives services from a company outside the organization’s
geographic region.
« * Nearshore outsourcing occurs when an organization receives services from a company within the organization’s
geographic region but outside its home country.
« *Onshore outsourcing occurs when an organization receives services from a company in the same country.
Review Questions
1. What is the major benefit of a software development methodology?
2. What aspects of software development does a methodology specify?
3. Name and briefly describe the phases of the systems development life cycle described in the chapter.
4. Name and briefly describe the aspects of feasibility described in the chapter.
5. Name and describe three alternatives to the traditional SDLC.
6. Name the advantages and disadvantages of each of the software development.methodologies described in the
chapter. .
7. List the advantages and disadvantages of custom; commercial, off-the-shelf (COTS); and hybrid approaches to
software.
8. List the main characteristics of custom-built and COTS software,
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
9. What are the main factors to consider when deciding whether to build or purchase software?
10. Define open source software.
11. What advantages does open source software offer to businesses?
12. List and briefly describe the outsourcing models presented in the chapter.
13. List the major benefits and risks of outsourcing.
14. What factors should organizations consider when deciding whether to outsource?
15. How do offshore, nearshore, and onshore outsourcing differ?
Reflection Questions
1. What is the most important thing you learned in this chapter? Why is it important?
2. What topics are unclear? What about them is unclear?
3. What relationships do you see between what you learned in this chapter and what you have learned in earlier
chapters?
4. How is the traditional systems development life cycle related to the major functions of an information system
that you learned about in Chapter 2?
5. What is the difference between functional and nonfunctional requirements? Why are they both important?
Which do you think is harder to determine? Why?
6. Your organization needs to build a system to help users carry out a business process that is very unique to your
organization.
a. Should your organization build this system from-scratch or use a COTS system? Why?What additional
information would be helpful in making this decision?
b. Do you think this should be outsourced? Why? What additional information would be helpful in making
this decision?
7. Commercial, off-the-shelf (COTS) software is often of higher quality lhan.custom built software. This is
especially true if the COTS software is widely used.
a. Why might COTS software be of higher quality?
b. Why would this be more likely if the COTS software is widely used?
8. What ethical issues are-related to the decision to outsource a function? Are these issues different for offshore,
nearshore, and onshore outsourcing?
9. There have been several instances of software development companies making formerly proprietary software
open source, (See http://en.wikipedia.org/wiki/List_of_formerly_proprietary_software for a partial list of
proprietary software that has been shifted to open source.) Why would a software development company do
this? What would the company potentially gain? What would it potentially lose?
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
10. Select two software development methods and discuss their possible impacts on information security (Chapter 8) and
privacy (Chapter 9).
10.A6. Find examples of software development projects for IoT. What are some of the additional issues developers face
when developing software for sensors, personal devices, and interconnected devices like those used in I0T?
10.A7. Find two examples of outsourcing (other than the examples in the book). Provide a brief (one-paragraph)
description of the outsourcing arrangements. State why the companies outsourced the work. Indicate which outsourcing
model best describes the example.
10.A8. This activity requires you to complete a case analysis of an information systems development project that was
outsourced. Your instructor can provide you with the case, or you may find it using the réference below. Nuwangi, S. M.,
and D. Sedera. 2020. “A Teaching Case on Information Systems Development Outsourcing: Lessons from a Failure.”
Communications of the Association for Information Systems 46. https://aisel.aisnet.org/cais/vol46/iss1/29/.
References
Boehm, B. 1988. “A Spiral Model of Software Development and Enhancement.” IEEE Computer 21(5): 61-72.
Grover, V., and J. T. C. Teng. 1993. “The Decision to Outsource Information Systems Function.” Journal of Systems Management
44(11): 34-38.
W3Techs. 2020. “Usage Statistics of Web Servers.” August 26. Retfieved from https://w3techs.com/technologies/overview/web_server.
Glossary
Application outsourcing: An outsourcing arrangement that involves a service provider handling activities related to a specific software
application.
DevOps: An approach to software development that focuses on rapid development of applications and services by integrating the
operations of the software with the development of the software.
Full or complete outsourcing: Contracting with a service provider to provide all IT-related services.
Functional requirements: Describes how a system should interact with users and other systems.
PRINTED BY: Moses Maenetje ([email protected]). Printing is for personal, private use only. No part of this book may be
reproduced or transmitted without publisher's prior permission. Violators will be prosecuted.
Nearshore outsourcing: Using a vendor that provides services from a location close to the client’s location.
Nonfunctional requirements: Constraints on a system.
Offshore outsourcing: Using a vendor that provides services from a location outside the client organization’s region.
Onshore outsourcing: Outsourcing to a firm located in the same country.
Open source software: Software that allows users to access the underlying source code for an application.
Outsourcing: An arrangement in which an organization contracts with a service provider to provide IT-related services.
Personnel outsourcing: An outsourcing arrangement in which a service provider places workers into an organization on a temporary
contract basis.
Process-based outsourcing: An arrangement in which an organization outsources a particular function or business process.
Project-based outsourcing: An outsourcing arrangement that involves contracting with a service provider to complete a specific
project.
Prototype: A small-scale mock-up of a system or a portion of a system.
Requirements elicitation: Gathering system requirements from various stakeholders.
Selective (partial) outsourcing: An outsourcing arrangement in which only certain aspects of IT are outsourced to a service provider.
Software development methodology: A framework for planning, structuring, and controlling software development projects.
Source code: Text-based computer programming language statements that can be read by humans.
Systems development life cycle (SDLC): A semisequential, phased approach to systems development.
Use case: Describes a series of actions that results in an outcome for an actor.