SDLC
SDLC
SDLC
Answers:
Because software can be very difficult and complex. We need the SDLC as a framework to guide the development to make it more systematic and efficient. We will be able to tell how long it will take to complete the project, to test and deploy. Not only that, you'll have an easier time debugging and finding flaws in the software program or make enhancement to it.
As like any other engineering development processes, software should have its own standardized process to accomplish the following: -->Proper Coding which comes only from proper design -->Reduces rework in the code in case of enhancements required -->Easy to modify code
The software development life cycle The software development life cycle, or SDLC, encompasses all of the steps that an organization follows when it develops software tools or applications. Organizations that incorporate security in the SDLC benefit from products and applications that are secure by design. Those that fail to involve information security in the life cycle pay the price in the form of costly and disruptive events. In an organization that's been around for several years or more, the SDLC is welldocumented and usually includes the steps that are followed and in what order, the business functions and/or individuals responsible for carrying out the steps and information about where records are kept. A typical SDLC model contains the following main functions: 1>Conceptual definition. This is a basic description of the new product or program being developed, so that anyone reading it can understand the proposed project. 2>Functional requirements and specifications. This is a list of requirements and specifications from a business function perspective. 3>Technical requirements and specifications. This is a detailed description of technical
requirements and specifications in technical terms. 4>Design. This is where the formal detailed design of the product or program is developed. 5>Coding. The actual development of software. 6>Test. This is the formal testing phase. 7>Implementation. This is where the software or product is installed in production.
Diff b/n SDLC & STLC ? Software Development Life Cycle (SDLC): It consists of 4 phases i)Requirements Analysis ii) System Design iii)Implementation iv) Testing i)Requirements Analysis:- In this the customers of the system provide the business requirements for the system. It is the analysts job to extract these requirements from the system and document them with sufficient clarity that the team know what to build to meet the customer needs. Analysts will do the feasibility of the requirements and put it on FDD. ii) System Design:- The architecture and details of how the system will work are created. These are documented by technical architects who produce documents such as UML diagrams. iii) Implementation:- The actual coding of the solution happens in this stage. iv)Testing:- Finally testing happens. The delivered code is tested against the requirements documents to ensure that the system being delivered meets the needs of the customer Software Testing Life Cycle (SDLC): It consists of 4 phases i) Requirements Analysis ii)System Design iii)Implementation iv)Testing i)Requirements Analysis:- Testing begins with the verification of ?requirements? documents. Testers need to analyse the requirements documents to ensure that they know exactly what the requirement is and that everyone has the same understanding. Removing ambiguity at this stage will remove bugs from later stages.A commonly used checklist for verifying requirements consists of the following: ? Correct Simply put, does the requirement correctly reflect what the user wants? ? Complete Ensure no elements are missing from the requirement, does the requirement describe all possible values, what about performance/security/accessibility aspects of a requirement? ? Consistent Checking that there are no contradictions within the requirements. ? Feasable Can the requirement be delivered given the technology, time and budget constraints. ? Testable Is the expected result known and can it be programatically or visually verified? Words like
?maximise? or ?adequate? can not be verified and should not be used in requirements. ? Traceable Is it clear which part of the system this requirement applies to, if it applies to more than one area is this clear? ? Unambiguous Look for ambiguous words like ?should? ?can? ?etc.? ?usually? ?and/or? ?quick? ii) System Design:-Once the System Design and Requirements are available they can be used to for Test Cases. Each Test Case has a Test Condition and procedure and an expected outcome. During this phase Testers, Designers and Developers should be working together to ensure that everyone understands the solution and the possible risks and weaknesses of the solution. Developers should be thinking about the unit tests they need to perform against the units they are developing, this includes the identification of any stubs or test harnesses that may be needed. Testers can use some of the Test Case Design Techniques to help them identify test cases that should be created. iii)Implementation / Development:- During the development of the solution ?unit tests? are executed against each of the units being developed.This is the first oppurtunity to test the application. iv)Testing:- It consists of 3 types a)Integration Testing:- consists of checking the data flow between two or more integrated modules b) Exploratory Testing:-is the simultaneous learning, creating and executing of test cases. In traditional methods the learning and test case creation is done ahead of time working from functional requirements. c) Functional Testing :-is the process of testing a system to verify that it meets the functional requirements. d) Load Testing:- is to check the system under expected load condition i.e How system behaves when ?concurrent users? accessing the same application. Testing an application under ?heavy loads?, such as testing of a web site under a range of loads to determine at what point the system?s response time degrades or fails. e) Performance Testing:- will make sure that product does not take up the much of the system resource and ?time taken to execute? the task. Imagine the reaction of the user if save operation takes up more than 5 minutes.and also testing will check that response time is meets the user requirement. There are no industry wide standard response time for web applications although there are some interesting writings on the matter. v)Reliability Testing:- is testing the ability of a system, to handle ?negative flow? or ?situations?E.x for example, if printer is not connected to your Application and if you have given Print Command The AUT Should not hang waiting for response from Printer Machine, it should have the facility to give error message and the system should recover to normal functionality. It is also known as recovery testing.vi) Regression Testing:- Regression testing can be defined as the retesting of a previously tested program following modification to ensure that faults have not been introduced or uncovered as a result of the changes made. The principle is that given a tested system and a new version of that system with some change made, a subset of the tests may be sufficient to restore the ?tested? status of the system. The value of separating out regression testing as a separate concept from simply re-testing the system completely is that when testing costs are high, being able to get the same verification from less testing is desirable. If the cost of a full system test is low, simply re-testing the system when changes are made is probably the best strategy. The extra work that has to be done to execute a regression test is determining the subset of the full system test required to bring the system back to ?tested? status. It is
possible, if the changes to the system are extensive enough, that the regression test will in fact be the same as the full system test. A regression test suite is created from selected test cases and scripts. Where possible regression testing should be automated to reduce the time taken to repeat these tests, in some cases the additional time required to automate the tests will outweigh the benefits