Book Image

Software Testing Strategies

By : Matthew Heusser, Michael Larsen
Book Image

Software Testing Strategies

By: Matthew Heusser, Michael Larsen

Overview of this book

Software Testing Strategies covers a wide range of topics in the field of software testing, providing practical insights and strategies for professionals at every level. With equal emphasis on theoretical knowledge and practical application, this book is a valuable resource for programmers, testers, and anyone involved in software development. The first part delves into the fundamentals of software testing, teaching you about test design, tooling, and automation. The chapters help you get to grips with specialized testing areas, including security, internationalization, accessibility, and performance. The second part focuses on the integration of testing into the broader software delivery process, exploring different delivery models and puzzle pieces contributing to effective testing. You’ll discover how to craft your own test strategies and learn about lean approaches to software testing for optimizing processes. The final part goes beyond technicalities, addressing the broader context of testing. The chapters cover case studies, experience reports, and testing responsibilities, and discuss the philosophy and ethics of software testing. By the end of this book, you’ll be equipped to elevate your testing game and ensure software quality, and have an indispensable guide to the ever-evolving landscape of software quality assurance.
Table of Contents (22 chapters)
1
Part 1:The Practice of Software Testing
9
Part 2:Testing and Software Delivery
14
Part 3:Practicing Politics

Shift left and shift right

One way to think of the waterfall model is that we build the wrong thing, then check it against the value for the customer, and then build the right thing. That is, it is not until the testing step that we actually check whether the ideas are going to work. The “Shift Left” paradigm is a plea to show quality earlier in the process. That might mean inviting programmers to participate in the requirement creation process or coming up with specific, clear acceptance criteria. Those acceptance criteria can be expressed as tests, either in plain English or BDD-style. For example, the requirements for valid and invalid passwords could include examples of valid and invalid passwords; not just “Must be at least 8 letters, of which one is a number and one a special character and one uppercase”, but actual examples of valid and invalid passwords. One bank we worked with, for example, would accept “&”, “<”...