310 likes | 516 Views
Modern Systems Analysis and Design Fourth Edition Jeffrey A. Hoffer Joey F. George Joseph S. Valacich. Chapter 4 System Testing & Implementation. Learning Objectives. Describe the process of coding, testing, and system conversion. Prepare a test plan for an information system.
E N D
Modern Systems Analysisand DesignFourth EditionJeffrey A. Hoffer Joey F. GeorgeJoseph S. Valacich Chapter 4 System Testing & Implementation
Learning Objectives • Describe the process of coding, testing, and system conversion. • Prepare a test plan for an information system. • Apply four installation strategies. • List deliverables for documentation, training, and user support. • Distinguish between system and user documentation. • Compare different user training modes. • Discuss issues of end-user support.
Purpose of System Implementation • To convert final physical system specifications into working and reliable software • To document work that has been done • To provide help for current and future users • Six major activities: • Coding • Testing • Installation • Documentation • Training • Support
The Process of Coding, Testing and Installation • Coding • Physical design specifications are turned into working computer code. • Testing • Tests are performed using various strategies. • Testing can be performed in parallel with coding. • Installation • The current system is replaced by the new system.
The Process of Documenting the System, Training Users, and Supporting Users • Two audiences for final documentation • Information systems personnel who will maintain the system throughout its productive life • People who will use the system as part of their daily lives • User Training • Application-specific • General: for operating system and off-the-shelf software
Software Application Testing • A master test plan is developed during the analysis phase. • During the design phase, unit, system and integration test plans are developed. • The actual testing is done during implementation. • Test plans provide improved communication among all parties involved in testing.
Test Classification • Manual vs. Automated • Static (syntax only) vs. Dynamic (execution)
Manual Testing Techniques • Inspection • A testing technique in which participants examine program code for predictable language-specific errors • Walkthrough • A peer group review of any product created during the systems development process; also called a structured walkthrough • Desk Checking • A testing technique in which the program code is sequentially executed manually by the reviewer
Automated Testing Techniques • Syntax Checking • The compiler is run against the source code to identify syntax errors. • Unit Testing • Each module is tested alone in an attempt to discover any errors in its code, also called module testing. • Integration Testing • The process of bringing together all of the modules that a program comprises for testing purposes. Modules are typically integrated in a top-down, incremental fashion.
Automated Testing Techniques (cont.) • System Testing • The bringing together of all the programs that a system comprises for testing purposes. Programs are typically integrated in a top-down, incremental fashion. • Stub Testing • A technique used in testing, especially where modules are written and tested in a top-down fashion, where a few lines of code are used to substitute for subordinate modules.
User Acceptance Testing • Actual users test a completed information system. • End result is the users’ final acceptance of the system. • Alpha testing: use simulated data • Beta testing: use real data in real user environment
Types of Alpha Tests • Recovery testing • Forces software (or environment) to fail in order to verify that recovery is properly performed • Security testing • Verifies that protection mechanisms built into the system will protect it from improper penetration • Stress testing • Tries to break the system • Performance testing • Determines how the system performs on the range of possible environments in which it may be used
Installation • The organizational process of changing over from the current information system to a new one • Four installation strategies: • Direct Installation • Parallel Installation • Single-location installation • Phased Installation 17.17
Running the old and new information systems at the same time until management decides the old system can be turned off
Trying out an information system at one site, then deciding if and how the new system should be deployed throughout the organization
Changing from the old information system to the new one incrementally, starting with one or a few functional components and then gradually extending the installation to cover the whole new system
Documenting the System • System documentation • Detailed information about a system’s design specifications, its internal workings and its functionality • Intended audience: maintenance programmers • Internal documentation: embedded in the program source code or generated at compile time • External documentation: includes data flow and entity-relationship diagrams
Documenting the System (cont.) • User Documentation • Written or other visual information about an application system, how it works, and how to use it
Training Information Systems Users • Potential training topics • Use of the system • General computer concepts • Information system concepts • Organizational concepts • System management • System installation
By far the most common training method is informal, via interaction with an in-house expert on the software
Electronic Performance Support Systems (EPSS), like Microsoft Office Assistant, are components of software applications that embed training and information for the user, in the form of tutorials, expert systems, and hyperlink jumps to reference topics.
Supporting Information Systems Users • Support is extremely important to users • Providing support can be expensive and time-consuming • One approach is through automation • Internet-based online support forums • On-demand fax • Voice response systems • Knowledge bases
Providing Support via Help Desk • A single point of contact for all user inquiries and problems about a particular information system or for all users in a particular department • Requires • Technical skills: extensive knowledge about how to use the system and typical problems that can be encountered • People skills: good listening and communication, dealing with complaints and frustrations
Summary • In this chapter you learned how to: • Describe the process of coding, testing, and system conversion. • Prepare a test plan for an information system. • Apply four installation strategies. • List deliverables for documentation, training, and user support. • Distinguish between system and user documentation. • Compare different user training modes. • Discuss issues of end-user support.