Testing Angular Applications
()
About this ebook
Testing Angular Applications is an example-rich, hands-on guide that gives you the real-world techniques you need to thoroughly test all parts of your Angular applications. By the end of this book, you'll be able to confidently write unit and end-to-end tests for Angular applications in TypeScript.
Foreword by Brad Green, Google.
Purchase of the print book includes a free eBook in PDF, Kindle, and ePub formats from Manning Publications.
About the Technology
Don't leave the success of your mission-critical Angular apps to chance. Proper testing improves code quality, reduces maintenance costs, and rewards you with happy users. New tools and best practices can streamline and automate all aspects of testing web apps, both in development and in production. This book gets you started.
About the Book
Testing Angular Applications teaches you how to make testing an essential part of your development and production processes. You'll start by setting up a simple unit testing system as you learn the fundamental practices. Then, you'll fine-tune it as you discover the best tests for Angular components, directives, pipes, services, and routing. Finally, you'll explore end-to-end testing, mastering the Protractor framework, and inserting Angular apps into your continuous integration pipeline.
What's inside
- Getting to know TypeScript
- Writing and debugging unit tests
- Writing and debugging end-to-end tests with Protractor
- Building continuous integration for your entire test suite
About the Reader
This book is for readers with intermediate JavaScript skills.
About the Author
Jesse Palmer is a senior engineering manager at Handshake. Corinna Cohn is a single-page web application specialist. Mike Giambalvo and Craig Nishina are engineers at Google.
Table of Contents
- Introduction to testing Angular applicationsPART 1 - Unit testing
- Creating your first tests
- Testing components
- Testing directives
- Testing pipes
- Testing services
- Testing the router PART 2 - End-to-end testing
- Getting started with Protractor
- Understanding timeouts
- Advanced Protractor topics PART 3 - Continuous integration
- Continuous integration
- Appendix A - Setting up the sample project
- Appendix B - Additional resources
Corinna Cohn
Corinna Cohn has been creating websites since 1995 and has written enterprise web apps for radio stations, scientific publishing, education, and business-to-business, with a focus on single-page applications since 2013. Corinna has written ugly, cryptic software in the past, but has committed to writing human-readable, unit-tested, and maintainable code from now on.
Related to Testing Angular Applications
Related ebooks
Angular Development with TypeScript Rating: 0 out of 5 stars0 ratingsASP.NET Core in Action, Second Edition Rating: 0 out of 5 stars0 ratingsAngular in Action Rating: 0 out of 5 stars0 ratingsDependency Injection Principles, Practices, and Patterns Rating: 5 out of 5 stars5/5Building Web APIs with ASP.NET Core Rating: 0 out of 5 stars0 ratingsTest Driven: Practical TDD and Acceptance TDD for Java Developers Rating: 0 out of 5 stars0 ratingsCamel in Action Rating: 0 out of 5 stars0 ratingsConcurrency in .NET: Modern patterns of concurrent and parallel programming Rating: 0 out of 5 stars0 ratingsCode like a Pro in C# Rating: 0 out of 5 stars0 ratingsLearning Android Application Testing Rating: 0 out of 5 stars0 ratingsContinuous Integration in .NET Rating: 0 out of 5 stars0 ratingsSpring Integration in Action Rating: 0 out of 5 stars0 ratingsTesting Java Microservices: Using Arquillian, Hoverfly, AssertJ, JUnit, Selenium, and Mockito Rating: 0 out of 5 stars0 ratingsDependency Injection: Design patterns using Spring and Guice Rating: 0 out of 5 stars0 ratingsMultithreading in C# 5.0 Cookbook Rating: 0 out of 5 stars0 ratingsEntity Framework Core in Action Rating: 0 out of 5 stars0 ratingsSpring Security in Action Rating: 0 out of 5 stars0 ratingsGit in Practice Rating: 4 out of 5 stars4/5Entity Framework Core Cookbook - Second Edition Rating: 0 out of 5 stars0 ratingsGetting MEAN with Mongo, Express, Angular, and Node Rating: 5 out of 5 stars5/5The Design of Web APIs Rating: 0 out of 5 stars0 ratingsJakarta EE for Java Developers: Build Cloud-Native and Enterprise Applications Using a High-Performance Enterprise Java Platform Rating: 0 out of 5 stars0 ratingsSpring MVC Cookbook Rating: 0 out of 5 stars0 ratingsModern Java in Action: Lambdas, streams, functional and reactive programming Rating: 2 out of 5 stars2/5Five Lines of Code: How and when to refactor Rating: 0 out of 5 stars0 ratingsEffective Unit Testing: A guide for Java developers Rating: 4 out of 5 stars4/5JUnit in Action Rating: 0 out of 5 stars0 ratingsSeriously Good Software: Code that works, survives, and wins Rating: 5 out of 5 stars5/5Test-Driven Java Development Rating: 4 out of 5 stars4/5
Programming For You
Coding All-in-One For Dummies Rating: 4 out of 5 stars4/5Python: Learn Python in 24 Hours Rating: 4 out of 5 stars4/5Python: For Beginners A Crash Course Guide To Learn Python in 1 Week Rating: 4 out of 5 stars4/5Access 2019 Bible Rating: 5 out of 5 stars5/5React Projects: Build 12 real-world applications from scratch using React, React Native, and React 360 Rating: 0 out of 5 stars0 ratingsPython for Finance Cookbook: Over 50 recipes for applying modern Python libraries to financial data analysis Rating: 0 out of 5 stars0 ratingsGrokking Algorithms: An illustrated guide for programmers and other curious people Rating: 4 out of 5 stars4/5Learn SAP Basis in 24 Hours Rating: 5 out of 5 stars5/5JavaScript: Advanced Guide to Programming Code with JavaScript Rating: 0 out of 5 stars0 ratingsHands-On Python for DevOps: Leverage Python's native libraries to streamline your workflow and save time with automation Rating: 0 out of 5 stars0 ratingsAlgorithms For Dummies Rating: 4 out of 5 stars4/5Python Programming : How to Code Python Fast In Just 24 Hours With 7 Simple Steps Rating: 4 out of 5 stars4/5How to Learn Microsoft Visio Quickly! Rating: 0 out of 5 stars0 ratingsHTML, CSS, & JavaScript All-in-One For Dummies Rating: 0 out of 5 stars0 ratingsLearn Algorithmic Trading: Build and deploy algorithmic trading systems and strategies using Python and advanced data analysis Rating: 0 out of 5 stars0 ratingsLearn JavaScript in 24 Hours Rating: 3 out of 5 stars3/5Python Machine Learning By Example Rating: 4 out of 5 stars4/5Learn PHP Programming in 7Days: Ultimate PHP Crash Course For Beginners Rating: 3 out of 5 stars3/5Learn NodeJS in 1 Day: Complete Node JS Guide with Examples Rating: 3 out of 5 stars3/5Python Games from Zero to Proficiency (Beginner): Python Games From Zero to Proficiency, #1 Rating: 0 out of 5 stars0 ratingsPYTHON: Practical Python Programming For Beginners & Experts With Hands-on Project Rating: 5 out of 5 stars5/5Javascript For Beginners: Your Guide For Learning Javascript Programming in 24 Hours Rating: 3 out of 5 stars3/5
Reviews for Testing Angular Applications
0 ratings0 reviews
Book preview
Testing Angular Applications - Corinna Cohn
Testing Angular Applications
Jesse Palmer
Corinna Cohn
Michael Giambalvo
Craig Nishina
with a Foreword by Brad Green
ManningBlackSized.pngManning
Shelter Island
For online information and ordering of this and other Manning books, please visit www.manning.com. The publisher offers discounts on this book when ordered in quantity.
For more information, please contact
Special Sales Department
Manning Publications Co.
20 Baldwin Road
PO Box 761
Shelter Island, NY 11964
Email: orders@manning.com
©2018 by Manning Publications Co. All rights reserved.
No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by means electronic, mechanical, photocopying, or otherwise, without prior written permission of the publisher.
Many of the designations used by manufacturers and sellers to distinguish their products are claimed as trademarks. Where those designations appear in the book, and Manning Publications was aware of a trademark claim, the designations have been printed in initial caps or all caps.
Recognizing the importance of preserving what has been written, it is Manning’s policy to have the books we publish printed on acid-free paper, and we exert our best efforts to that end. Recognizing also our responsibility to conserve the resources of our planet, Manning books are printed on paper that is at least 15 percent recycled and processed without the use of elemental chlorine.
Manning Publications Co.
20 Baldwin Road
PO Box 761
Shelter Island, NY 11964
Development editors: Cynthia Kane and Toni Arritola
Technical development editors: Doug Warren and Nick Watts
Copyeditor: Carl Quesnel
Proofreader: Melody Dolab
Technical proofreader: Luis Carlos Sanchez Gonzalez
Typesetter: Happenstance Type-o-Rama
Cover designer: Marija Tudor
ISBN 9781617293641
Printed in the United States of America
1 2 3 4 5 6 7 8 9 10 – SP – 23 22 21 20 19 18
To my wife, whose love and support helped me get through many long nights and weekends while working on the book. Your accomplishments inspire me to do my best every day.
To my parents, who passed down to me their work ethic and provided me with opportunities to succeed in life, for which I am forever grateful.
—Jesse Palmer
To my dear friends, who encouraged me to keep writing!
—Corinna Cohn
To my wife, who has been consistently and limitlessly supportive over the many long nights these past few months.
—Michael Giambalvo
To my parents, whose hard work and sacrifice afforded me many opportunities, and to my wife, who supports me in all that I do.
—Craig Nishina
foreword
I’ve known Jesse Palmer for many years as part of the Angular community, so I was excited when he told me he’d be writing a book specifically focused on testing for Angular projects. I’ve seen firsthand how hard it can be to do a great job at automated testing on some of the world’s biggest applications. As a result, when I started the Angular project, I wanted to make sure everything we did contributed to making testing easier and even a joyful experience.
I was hired at Google primarily for my experience in testing, and my first roles here were in improving test techniques, infrastructure, and adoption of testing for products like Gmail, Google Calendar, and Google Docs.
At Angular’s core, we’ve set the application architecture itself to be testable, with dependency injection, mocks, and API hooks for end-to-end testing. We’ve built tools like Protractor for easy, stable, and fast end-to-end tests. We built Karma for a great developer experience in unit testing. And there’s still more to do!
This book picks up where we on the Angular team left off. It provides guidance on the overall strategy for how to think about testing on your projects to get the best return on your investment. It dives into specifics for testing different aspects of your applications. And it covers what are often regarded as advanced topics, such as setting up continuous integration for your tests and doing screenshot diff testing.
So here’s my big thank you to Jesse, Corinna, Mike, and Craig for writing this book and helping to build a stronger, smarter Angular community.
And thanks to you for being part of the Angular community and taking the time to improve your skills.
Brad Green Engineering Director for Angular at Google
preface
Back in 2013, I was working on a content management system that used AngularJS heavily, and the expectation was that we have 80% unit-test coverage. My team struggled . . . a lot. You couldn’t find many materials on testing at the time. It was easy to find a blog post here and there, but it was hard to find something that guided you through everything you needed to know to be successful writing tests in a complete package.
I kept thinking to myself, someone needs to write a book on this. I knew it would be challenging to cover all of the potential use cases, but someone could at least give enough foundational knowledge to show people where to start. Plus, with the upcoming rewrite to Angular 2, there would be a need for quality content regarding testing. The idea for Testing Angular Applications was born.
One day in 2015, Manning Publications contacted me to review a proposal for another Angular book. I agreed, and they sent me a questionnaire to fill out. I was ecstatic to see a question at the end of the questionnaire asking if I had an idea for a book. Of course I did! This was my chance to pitch my book, and I was thrilled at the opportunity. Shortly after I pitched it, Manning gave me a contract to sign that marked the book’s official beginning. Along the way, I was lucky enough to add three wonderful authors who helped bring tremendous value to the effort.
Now is a great time to get into testing Angular applications, if you haven't already. Since the early days of testing AngularJS applications, the platform has matured dramatically. The Angular CLI comes with numerous testing commands that make running tests a breeze. It also handles all installation of the testing tools, which saves time and prevents headaches as you set up your test suite. A lot of helpful tools available within Angular, like TestBed and ComponentFixture, aid in unit testing. Additionally, Protractor has matured and is stable, making end-to-end testing much easier.
In your hands or on your monitor, tablet, phone, or e-reader, or any other device, is everything you need to know to get started with testing Angular applications. My fellow coauthors and I have put a lot of time and effort into getting you up and running with testing. In many ways, we set out to write the book that we wished we had when we first started writing tests for Angular. We hope you enjoy reading and using the book as much as we did writing it.
Jesse Palmer
acknowledgments
We’d like to acknowledge the work of editors Cynthia Kane and Toni Arritola. Toni stepped into the process long after work on the book started, but she propelled us forward and to the finish line. It isn’t an exaggeration to say that Toni is the reason you’re able to read this book. Our technical proofreader, Luis Carlos Sanchez Gonzalez, was an invaluable help. Thanks also to the Manning reviewers, whose insightful comments helped make this book the best it could be: Bradley Suira, Desmond Horsley, Dinesh Arora, Jason Pike, Jim Schmehil, Nathan Roberts, Rafael Avila Martínez, Rainer Jeschor, Sergey Evsikov, Shobha Iyer, Siva Kumar Boyapati, Steve Atchue, Tahir Awan, and Zorodzayi Mukuya.
Jesse would like to acknowledge his former manager, Shawn Ward, who taught him the value of testing. Ward Bell also deserves credit for helping debug tests, writing the testing documentation on Angular.io, and insisting that he use the Angular CLI, which greatly changed the direction of the book for the better.
Heartfelt thanks go to Brad Green for getting Jesse interested in contributing to Angular in the first place and Peter Bacon Darwin for bringing him into the Angular organization. Finally, Jesse would like the thank his coauthors, Corinna Cohn, Craig Nishina, and Michael Giambalvo, for coming on board and helping to complete the book. The book wouldn’t be what it is now without their valuable contributions.
Corinna would like to thank Samantha Quiñones, whose service to the developer community as a teacher and speaker inspired her to learn about unit testing, and who encouraged her to introduce testing practices to her organization. She also thanks Igor Minar and Miško Hevery for spending their time in person teaching newbie developers the basics of Angular and inspiring developers like Corinna to take a step into a larger world.
Craig would like to thank his previous team, Julie Ralph, Michael Giambalvo, and Sammy Jelin, for ramping him up on Protractor and reviewing all of his pull requests. He’d also like to thank Evan Harris, who years ago took him to his first Seattle Google Developers Group Meetup to learn about AngularJS.
Michael would like to thank Craig Nishina for bringing him in on this book. Special thanks to Julie Ralph, Sammy Jelin, and Craig Nishina for all the hard work they did on Protractor. Thanks to the Angular team for being consistently focused on creating a great community!
about this book
Testing Angular Applications exists to help developers better understand one of the trickier parts of using the power of Google’s Angular framework: writing testable, reliable code. Angular departs wildly from the earlier AngularJS framework, introducing developers to a slew of new concepts not familiar from AngularJS or any other JavaScript framework. Writing unit tests and end-to-end tests requires a deeper knowledge of Angular than even the most heroic of tutorials can convey. Angular written for production should be backed by a set of reliable and useful tests, and with this book, we equip the reader with the knowledge to deliver those tests.
Who should read this book
Whether you’re an experienced developer contributing to an enterprise-scale Angular application or new to Angular and hoping to gain a deeper understanding of the framework, this book will help you understand the fundamentals of writing testable code. Angular is evolving at a rapid pace, faster than the official documentation can match. Supplemental material such as this book goes beyond the online documentation by providing step-by-step examples that explain not only the how but also the whys of unit testing in Angular. This book assumes a comfortable knowledge of JavaScript and some knowledge of TypeScript, a superset of JavaScript that adds a variety of new language features.
This book reflects many hours of real-world experience understanding and applying the Angular framework for both unit and end-to-end tests. As authors, we’ve read the online documentation, delved into the Angular source code, upgraded Angular multiple times (along with the example application written for this book), applied multiple Angular testing APIs, and created realistic examples covering each major system of Angular.
If you need to write testable Angular code and want to take advantage of our experience of having already walked the path, this book will help you on your testing journey.
How this book is organized: a roadmap
The book has three parts that cover 11 chapters. Two appendixes include supplemental content:
Chapter 1 provides a gentle introduction to testing Angular applications. It offers background information on TypeScript and touches on the differences between unit testing and end-to-end testing. It also gives you an overview of the different tools—Jasmine, Karma, and Protractor—you’ll use throughout the book.
Part 1 covers the most common concepts that you’ll need to understand to write unit tests for Angular:
Chapter 2 will get your testing skills warmed up by writing basic tests. It discusses how to use key parts of the Jasmine framework, including beforeEach, afterEach, it, describe, and matcher functions. You’ll also learn how to test classes.
Chapter 3 discusses how to test the most fundamental concept in Angular: components. It introduces common testing classes and functions, and you’ll learn the differences between shallow and isolated tests.
Chapter 4 describes testing directives. You’ll learn how to test two types: attribute directives and structural directives.
Chapter 5 covers testing pipes. You’ll learn about the transform function, which is essential learning for writing tests for pipes. You’ll also learn about pure functions.
Chapter 6 discusses how to test services. The chapter covers how to test services that use the Angular HTTP class, how to test services using promises and RxJS observables, and how to use stubs to create isolated unit tests. The chapter also covers dependency injection with unit tests for services.
Chapter 7 goes deep into the subject of testing routing. Topics the chapter covers include configuring the router, testing components that use the router, and testing advanced router configurations.
Part 2 covers how to write end-to-end tests with Protractor:
Chapter 8 covers how to get started with Protractor. You’ll learn about how Protractor works, how to write your first Protractor tests, how to interact with elements, how to interact with a list of elements, and how to organize the tests with page objects.
Chapter 9 discusses timeouts. It goes into detail about understanding the causes of timeout errors in Protractor and how to avoid them, waiting for specific changes in your app, and understanding flakiness with Protractor and how to eliminate it.
Chapter 10 dives into advanced Protractor topics, like configuration files, screenshot testing, and debugging tests.
Part 3 is about continuous integration:
Chapter 11 demonstrates how to set up a continuous integration server that will automatically run all the tests you’ve been writing. Doing so will help you find bugs as soon as possible.
Appendix A covers setting up the sample project, and appendix B includes additional resources for you to consider.
In general, you can read the book from front to back, or you can pick and choose which chapters you want to read. Most chapters use the sample app, which you can install using appendix A, so you may want to get that set up before skipping around the book.
About the code
This book contains many examples of source code, both in numbered listings and inline with normal text. In both cases, this code is formatted in a fixed-width font like this to separate it from ordinary text. Sometimes code is also in bold to highlight when it has changed from previous steps in the chapter, such as when a new feature adds to an existing line of code.
In many cases, we’ve reformatted the original source code; we’ve added line breaks and reworked indentation to accommodate the available page space in the book. In rare cases, even this wasn’t enough, and listings include line-continuation markers (➥). Additionally, we’ve often removed comments in the source code from the listings when the code is described in the text, but code annotations accompany many of the listings to highlight important concepts.
You can find the accompanying code for the book on the book’s webpage at manning.com (www.manning.com/books/testing-angular-applications) and also on GitHub at http://mng.bz/z22f. To execute the code, you need to have Node.js version 6.9.0 or higher and npm version 3 or higher. You can use a Windows, Mac, or Linux machine. We wrote the code for this book on a Mac, so your experience may vary slightly. You can find installation instructions in appendix A.
Book forum
Purchase of Testing Angular Applications includes free access to a private web forum run by Manning Publications where you can make comments about the book, ask technical questions, and receive help from the author and from other users. To access the forum, go to https://forums.manning.com/forums/testing-angular-applications. You can also learn more about Manning's forums and the rules of conduct at https://forums.manning.com/forums/about.
Manning’s commitment to our readers is to provide a venue where a meaningful dialogue between individual readers and between readers and the author can take place. It is not a commitment to any specific amount of participation on the part of the author, whose contribution to the forum remains voluntary (and unpaid). We suggest you try asking the authors some challenging questions lest their interest stray! The forum and the archives of previous discussions will be accessible from the publisher’s website as long as the book is in print.
about the authors
jesse_palmer_mug.tifJesse Palmer
started programming back in the day when BASIC was still a thing. He spent much of his early childhood developing video games on his sweet Atari 400. Jesse started off his professional career by slinging ColdFusion, PHP, ASP.NET, and Java. Around 2013, he started his first contributions to AngularJS and thought that maybe this whole AngularJS thing had legs.
Jesse now finds himself as a Senior Engineering Manager at Handshake where he leads the Student Engineering organization. When Jesse isn't programming, you can find him playing video games or cheering on his beloved Virginia Tech Hokies. He lives with his wife, Elizabeth, and his two cats, Nicky and Gracie, in San Francisco.
Corinna_Cohn_Headshot.tifCorinna Cohn
is a web developer with more than 20 years of experience building websites and writing web applications. Corinna takes responsibility for having written ugly, unmaintainable code but is now working to bring the principles of clean code, unit tests, and high-quality refactoring into the realm of JavaScript web applications.
craignishina.pngCraig Nishina
is a software engineer at Google. He is currently working on Google Cloud Platform and contributes to Protractor, the end-to-end test framework for Angular. In an earlier career, Craig worked as a civil engineer designing buildings, but he much prefers writing code to designing building structures. When he’s not contributing to open source projects like Protractor and webdriver-manager, he enjoys playing golf and traveling.
MichaelGiambalvo.tifMike Giambalvo
is a developer with a passion for creating testable, quality code. He is currently at Google working on the UI for Google Cloud Platform and has contributed to Angular and Protractor, the end-to-end test framework for Angular applications. He enjoys learning new things and helping others learn and is a cofounder of the Angular Seattle Meetup group. In his copious free time, he enjoys hiking and building crappy robots.
about the cover illustration
The figure on the cover of Testing Angular Applications is captioned Habit of a Moor of Arabia.
The illustration is taken from Thomas Jefferys’ A Collection of the Dresses of Different Nations, Ancient and Modern (four volumes), London, published between 1757 and 1772. The title page states that these are hand-colored copperplate engravings, heightened with gum arabic.
Thomas Jefferys (1719–1771) was called Geographer to King George III.
He was an English cartographer who was the leading map supplier of his day. He engraved and printed maps for government and other official bodies and produced a wide range of commercial maps and atlases, especially of North America. His work as a map maker sparked an interest in local dress customs of the lands he surveyed and mapped, which are brilliantly displayed in this collection. Fascination with faraway lands and travel for pleasure were relatively new phenomena in the late 18th century, and collections such as this one were popular, introducing both the tourist as well as the armchair traveler to the inhabitants of other countries.
The diversity of the drawings in Jefferys’ volumes speaks vividly of the uniqueness and individuality of the world’s nations some 200 years ago. Dress codes have changed since then, and the diversity by region and country, so rich at the time, has faded away. It’s now often hard to tell the inhabitants of one continent from another. Perhaps, trying to view it optimistically, we’ve traded a cultural and visual diversity for a more varied personal life—or a more varied and interesting intellectual and technical life.
At a time when it’s difficult to tell one computer book from another, Manning celebrates the inventiveness and initiative of the computer business with book covers based on the rich diversity of regional life of two centuries ago, brought back to life by Jeffreys’ pictures.