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

Summary

This chapter focused on how programmers approach software testing, which tends to be bottom-up – that is, programmers build the software, bit by bit. If they can find a reason to have confidence that the individual bits fit together well, then there’s a chance the entire system can work effectively. However, if the individual parts do not work well, the entire system will be hopeless. To do that, we talked about developing components that can be tested in isolation, calling the separation between the components a “seam.”

We also described the hexagonal architecture, which is a way to think about how those components interact. Once we can isolate what a small developer “unit” is, we can describe unit tests, along with a particular discipline within unit testing called TDD. After explaining TDD, we covered ways to isolate the code to test one component, including the use of test doubles. This chapter included coverage of mutation testing...