Foundation level syllabus
Fundamentals of testing
software systems
- software systems are an main part of life. most people had an experience with the software systems.
- software does not work correctly it can lead to many problems like loss of money, death, injury etc....
Causes of software defects.
- A developer can make an error mistakes in the program , which produces a defect
- Defected code is executed, system produces failure results.
- Defects can be occur because of time pressure, complex code, complexity of infrastructure, technologies etc.
- Failure can be caused by environmental conditions
Role of testing in software development, maintenance, operation
- Rigorous testing of software system can helps us to reduce the problem , if the defects are foun are corrected before the system is released.
Testing and quality
- In functional and non functional requirements , it is possible to measure the quality of software in terms of defects
- (i.e ) reliability, usability, efficiency, maintainability and portability )
- A properly designed tests that passes reduces the overall level of risk in the systems. when testing finds defects, the quality of software system increases. when those defects are fixed.
- lessons should be learned from previous projects and understanding the root causes of the defects found in other projects. processes can be improved.
- Should prevent the defects from reoccurring and improve the quality of future systems. This is knows as quality assurance.
- Testing should be integrated as one of the quality assurance activities
How much testing is enough
- How much testing is enough, this decision should take account of the level of risk, technical safety, business risks, time and budget,
What is Testing
- A common definition of testing is that consists of running the tests. executing the software is not at all testing. It contains many features before and after executions.
- Testing activities include planning controls, test conditions, designing and executing the test cases.checking the results, reporting the test process and finalizing and completing the closure activities.
- Both dynamic and static testing can be used for achieving the similar objectives and provide information that can be used to both testing activities, documents and development process.
Testing have the following objectives.
- Finding defects
- Gaining confidence about the level of quality
- Providing information for the decision making
- Preventing defects
Steps to prevent defects in the early stage
- The process involved in designing tests in the early life cycle that can help to prevent people from defects introducing into code.
- Review of documents and the identification of requirements also help to prevent defects appearing in the code.
- Different view points in testing takes different objectives. Main objective of development testing may cause as failures, so that defects in the software are identified and its fixed.
- For acceptance testing, the main objective is to confirm that the system works as expected to met his requirements.
- In some cases, the main objective of testing , may be to assess the quality of software to give the information to the stake holders of the risk or releasing the system at a given time.
- Main objective of maintenance team, no new defects have been introduced during the development of changes.
- Main objective of operational testing, assess system characteristics such as reliability or availability.
- Debugging and testing are different . dynamic testing can chow failures caused by defects.
- Debugging is the development activity that finds and analyze and removes the causes of failure.
- Subsequent retesting by a tester ensures that the fix does not indeed resolves the failure.
- The responsibility for these activities is testers do test process and developers do debug process.
Seven testing principles
Testing shows presence of defects
- Testing can shows that defects are present, but cannot prove that there are no defects in the software.
- Testing can reduces the probability of undiscovered defects remaining in the software , even if no defects are found , it is not a proof of correctness.
Exhaustive testing is impossible
- Testing everything is not possible except for trival cases.
- Instead of exhaustive testing, risk analysis and priorities should be used to focus testing efforts.
Early testing
- To find defects in the early stages, testing activities shall be treated as early as possible in the software or system development life cycle and should be focused on defined objectives.
Defect clustering
- Testing efforts shall be focused proportionally to the expected and later observed defect density of modules.
- A small number of modules usually contains most of the defects discovered during the prerelease testing or responsible for the most of the operational failures.
Pesticide Paradox
- If the same tests are repeated over and over, the same set of test cases will move to the new defects.
- To overcome this, we need to be regularly and revised the documents.
- new and different tests need to be written to excercise different parts of the software or systems to find more defects.
Testing is context dependent
- Testing is done differently in different context.
- Gaming site is tested differently from e-commerce site.
Absence of errors fallacy
- Finding and fixing the defects does not help , if the systems built is unusable and does not fulfill the users needs and expectations.
No comments:
Post a Comment