Preface xvii
Chapter 1: Introduction to Ethical Hacking....1
Chapter 2: Building a Penetration Testing Lab....31
Chapter 3: Setting Up for Advanced Penetration Testing Techniques....83
Chapter 4: Passive Reconnaissance....117
Chapter 5: Exploring Open-Source Intelligence....143
Chapter 6: Active Reconnaissance....203
Chapter 7: Performing Vulnerability Assessments....241
Chapter 8: Understanding Network Penetration Testing....283
Chapter 9: Performing Network Penetration Testing....327
Chapter 10: Post-Exploitation Techniques....375
Chapter 11: Delving into Command and Control Tactics....427
Chapter 12: Working with Active Directory Attacks....475
Chapter 13: Advanced Active Directory Attacks....527
Chapter 14: Advanced Wireless Penetration Testing....565
Chapter 15: Social Engineering Attacks....617
Chapter 16: Understanding Website Application Security....639
Chapter 17: Advanced Website Penetration Testing....687
Chapter 18: Best Practices for the Real World....743
Appendix....767
Summary....788
Index....791
Experienced developers understand the importance of designing a comprehensive testing strategy to ensure efficient shipping and maintaining services in production. This book shows you how to utilize test-driven development (TDD), a widely adopted industry practice, for testing your Go apps at different levels. You'll also explore challenges faced in testing concurrent code, and learn how to leverage generics and write fuzz tests.
The book begins by teaching you how to use TDD to tackle various problems, from simple mathematical functions to web apps. You'll then learn how to structure and run your unit tests using Go's standard testing library, and explore two popular testing frameworks, Testify and Ginkgo. You'll also implement test suites using table-driven testing, a popular Go technique. As you advance, you'll write and run behavior-driven development (BDD) tests using Ginkgo and Godog. Finally, you'll explore the tricky aspects of implementing and testing TDD in production, such as refactoring your code and testing microservices architecture with contract testing implemented with Pact. All these techniques will be demonstrated using an example REST API, as well as smaller bespoke code examples.
By the end of this book, you'll have learned how to design and implement a comprehensive testing strategy for your Go applications and microservices architecture.
Create practical Go unit tests using mocks and assertions with Testify
Build table-driven test suites for HTTP web applications
Write BDD-style tests using the Ginkgo testing framework
Use the Godog testing framework to reliably test web applications
Verify microservices architecture using Pact contract testing
Develop tests that cover edge cases using property testing and fuzzing
If you are an intermediate-level developer or software testing professional who knows Go fundamentals and is looking to deliver projects with Go, then this book is for you. Knowledge of Go syntax, structs, functions, and interfaces will help you get the most out of this book.