EARN 400$ PER WEEK

Custom Search

Tuesday, November 9, 2010

Black Box Approach:

Functional testing approach focuses on application externals. We can call it as Requirements-based or Specifications-based.

Characteristics:

  1. Functionality
  2. Requirements, use, standards Correctness
  3. Business forms, Documents
  4. Does system meet business requirements

Type of Test during Black Box Approach:

  1. System Testing: System test demonstrates that all programs function and work together as designed. This test is performed when all the individual component objects for a release have been integrated into a single system. Documented non-functional requirements such as performance, volume, stress, capacity and security are also verified. Particular attention is paid to regression testing during this phase.
  2. User Acceptance Testing: The testing performed for or by user is called user acceptance testing or UAT. The purpose is to ensure that end users are satisfied with the functionality and performance of the system.

Techniques & Tools:

  1. Equivalence partitioning – Develop program code to perform tests
  2. Boundary value analysis – Develop program code to perform tests
  3. Cause-effect graphing – Flow graphing tools
  4. Random testing – GUI test tools
  5. Error Guessing – GUI test tools
  6. Regression testing – GUI / Server test tools
  7. Stress testing – Load test tools
  8. Replication testing - Load test tools
  9. Data Integrity testing – Data analysis tools
  10. Backup and recoverable testing – Load test tools / Server test tools / GUI test tools
  11. Configuration testing – Multi platform test tools
  12. Performance Testing – Load test tools
  13. Functional testing – Load test tools / GUI test tools / Server test tools
  14. Security testing – Security test tools
  15. Operational Readiness Testing – Load test tools / server / GUI tools
  16. User Acceptance testing – GUI test tools
  17. Compatibility / conversion testing – Load / GUI / Server test tools
  18. Benchmark Testing – Benchmarking tools
  19. Usability testing – Usability measurement tools
  20. Alpha / Beta testing – Load / Server / GUI test tools

Monday, November 8, 2010

White Box Approach:

Structural testing approach focuses on application internals. We can call it as Program-based.

Characteristics:

  1. Module design
  2. Implementation
  3. Do modules / functions meet functional and design specifications?
  4. Do program structures meet functional and design specifications?
  5. How does the program work?

Type of Test during White Box Approach:

  1. Unit Testing: To verify the pieces of code against the design, to remove problems from the code, and to ensure that each component of the code executes according to functional and design specifications. Generally, developers do unit testing.
  2. Integration Testing: To verify that each software unit interfaces correctly with other software units. Developers, also testers perform integration testing.

Techniques & Tools:

  1. Fault insertion – Coding tools
  2. String Test – GUI and Server test tools
  3. Error handling – Error handling Tools
  4. Statement coverage – Static and Dynamic Analyzers
  5. Decision coverage - Static and Dynamic Analyzers, Coverage analysis Tools
  6. Condition coverage - Static and Dynamic Analyzers, Coverage analysis tools
  7. Path coverage - Static and Dynamic Analyzers, Coverage analysis tools
  8. Data flow coverage – Data modeling tools, Flow diagram editors
  9. Memory leak – Memory usage tools
  10. Cyclomatic complexity – Cyclomatic complexity Analyzers

Why does software have bugs?

1. Miscommunication or no communication - as to specifics of what an application should or shouldn't do (the application's requirements).

2. Software complexity - the complexity of current software applications can be difficult to comprehend for anyone without experience in modern-day software development. Windows-type interfaces, client-server and distributed applications, data communications, enormous relational databases, and sheer size of applications have all contributed to the exponential growth in software/system complexity. And the use of object-oriented techniques can complicate instead of simplify a project unless it is well engineered.

3. Programming errors - programmers, like anyone else, can make mistakes.

4. Changing requirements - the customer may not understand the effects of changes, or may understand and request them anyway - redesign, rescheduling of engineers, effects on other projects, work already completed that may have to be redone or thrown out, hardware requirements that may be affected, etc. If there are many minor changes or any major changes, known and unknown dependencies among parts of the project are likely to interact and cause problems, and the complexity of keeping track of changes may result in errors. Enthusiasm of engineering staff may be affected. In some fast-changing business environments, continuously modified requirements may be a fact of life. In this case, management must understand the resulting risks, and QA and test engineers must adapt and plan for continuous extensive testing to keep the inevitable bugs from running out of control.

· Time pressures - scheduling of software projects is difficult at best, often requiring a lot of guesswork. When deadlines loom and the crunch comes, mistakes will be made.

· Egos - people prefer to say things like:

·           'no problem' 
·           'piece of cake'
·           'I can whip that out in a few hours'
·           'it should be easy to update that old code'
·          
·          instead of:
·           'that adds a lot of complexity and we could end up
·              making a lot of mistakes'
·           'we have no idea if we can do that; we'll wing it'
·           'I can't estimate how long it will take, until I
·              take a close look at it'
·           'we can't figure out what that old spaghetti code
·              did in the first place'
·          
·          If there are too many unrealistic 'no problem's', the
·          Result is bugs.
·          

5. Poorly documented code - it's tough to maintain and modify code that is badly written or poorly documented; the result is bugs. In many organizations management provides no incentive for programmers to document their code or write clear, understandable code. In fact, it's usually the opposite: they get points mostly for quickly turning out code, and there's job security if nobody else can understand it ('if it was hard to write, it should be hard to read').

6. Software development tools - visual tools, class libraries, compilers, scripting tools, etc. often introduce their own bugs or are poorly documented, resulting in added bugs.

Wednesday, November 3, 2010

Software Development Life Cycle (SDLC)

Water Fall Model:


There are seven stages of the software development life cycle:

  1. Initiate the project – The users identify their Business requirements.
  1. Define the project – The software development team translates the business requirements into system specifications and put together into System Specification Document.
  1. Design the system – The System Architecture Team designs the system and writes Functional Design Document. During design phase general solutions re hypothesized and data and process structures are organized.
  1. Build the system – The System Specifications and design documents are given to the development team code the modules by following the Requirements and Design document.
  1. Test the system - The test team develops the test plan following the requirements. The software is build and installed on the test platform after developers have completed development and Unit Testing. The testers test the software by following the test plan.

  1. Deploy the system – After the user-acceptance testing and certification of the software, it is installed on the production platform. Demos and training are given to the users.
  1. Support the system - After the software is in production, the maintenance phase of the life begins. During this phase the development team works with the development document staff to modify and enhance the application and the test team works with the test documentation staff to verify and validate the changes and enhancement to the application software.

QA process starts from the second phase of the Software Development Life Cycle i.e. Define the Project. Actual Product testing will be done on Test the system phase (Phase-5). During this phase test team will verify the actual results against expected results.