In-Sprint Test Automation On Agile Teams: Yes You Can!
Ministry of Testing
Ministry of Testing is where software testing professionals grow their careers.
Boost Agile process reliability, project engagement and teamwork with in-sprint test automation
By Swathika Visagn ????????????♀???♀?
¨My bold ask to the stakeholders was to support?“a safe space to fall down and get back up again.” I made it clear that a period of trial and error was essential, since it would offer priceless lessons that would only make our process more resilient and reliable over time.¨
If you're like me, you may have read or heard about in-sprint test automation… and wondered why such an elusive goal was high priority. After all, the goal is just about impossible for testers alone to reach.?
But even if there’s only one dedicated tester on your team, in-sprint test automation is in fact within reach! You can make it work when the entire development team, including the product manager and scrum master, set in-sprint test automation as a goal for the entire team, not just the tester.?
I had to try in-sprint test automation myself before I realized any of this. And I'm happy to report that with the right understanding and support in place, it's more than possible; it's a great way to work.?
Here, I share my experience report: There have been lows, there have been highs, and it was never an easy sail. I’ll share successes, lessons learned, and even a couple of silly true confessions!
My First Words Of Advice: Learn Your Test Automation Craft Well
When my team first began to consider in-sprint test automation,?I was already comfortable with test automation principles in general, and Cypress and continuous integration / development (CI / CD) specifically. If I'd had to come up to speed with that knowledge as we moved into in-sprint test automation, the result would likely not have been optimal, to put it mildly. So if you're new to test automation or the automation toolset you'll use, take the time to learn the ropes before you attempt in-sprint test automation.?
In-Sprint Test Automation: Shift-Left Testing In Practice
We probably all have heard the term "shift-left¨ with respect to what ¨testing¨ means in the Agile context. (Be assured that if you put in-sprint test automation into practice, your team will exemplify good shift-left principles!)?
Below are a few good habits to get into as you adopt a shift-left mindset:
Surveying The Territory
From the outset, I was actively involved in the project, which was a complete refresh of legacy software. The complexity of the old code and the number of improvements envisioned would require all new code to be written. The developers got busy right away with proofs of concept.
I had at least one clear advantage: the legacy project docs and test automation framework set me up perfectly to understand the crux of the project, who the end users were, what the key product features were, and what overall improvements to quality I could suggest. I made a list of all possible test oracles I could get and made the utmost use of all of them. I watched the knowledge transfer videos from the legacy project and learned about the various layers and integration points between the features. And I met with the senior test automation engineer for the legacy project, whose explanation and guidance were excellent.?
The availability of all of these resources inspired me to make the most of my early engagement.?
Making A Roadmap?
I have always been a huge fan of mind maps, so I used Lucidchart to make a diagram of the application user journey. I adapted a basic concept map by using shapes available from the Lucidchart gallery. I have drawn my inspiration from a Lucidchart?blog which shows the various ways of building mind maps efficiently.?
The mind map (see Fig. 2) helped me to understand what each application page offered to the user, how it drove the user’s actions, and how each user action was reflected in the various sections of the application. Diving deep into an application like this gives testers a clear idea of the business purpose and the value the application offers to the users. And it only boosted my confidence, which I would need to advocate for quality as an important member of the team.?
I presented the mind map to the team in a sprint demo. One unanticipated win: the stakeholders were delighted because they could use the mind map to compare the product we were developing with the legacy product.?
Sharing My Ideas And Plans With The Team
As I am the only tester in the team, I believe it's my responsibility to explain to the team my ways of working and how the QA tasks flow across the sprint.?
So for this first go at in-sprint test automation, I created a Lucidchart diagram (see Fig. 3) that showed how QA tasks flow in parallel to developer tasks and illustrated ideas to improve communication between testers and developers.?My team appreciated that I made my process transparent to them, which enhanced communication going forward. It also helped everyone understand that we had a common goal.?
I created the diagram to explain and help the team visualize testing activities. The key points that I illustrated were:
Time For A Pep Talk
Since we were attempting in-sprint test automation for the very first time as a team, I figured that some psychological preparation was in order. So I gave a presentation to the team, and invited discussion. Our conversation was rewarding.?
For each activity and goal, we talked about:?
My bold ask to the stakeholders was to support?“a safe space to fall down and get back up again.” I made it clear that a period of trial and error was essential, since it would offer priceless lessons that would only make our process more resilient and reliable over time.?
Key To Success: A Solid Proof Of Concept
I knew there were some areas where I personally needed to upskill. I identified at least two:
Then I created a proof of concept using the Cypress BDD framework with Cucumber. I read about accessibility testing from various resources, and I learned that Cypress has its very own accessibility testing plug-in: Cypress-Axe. I incorporated that into my proof of concept.
So I had a skeleton framework all ready to go, awaiting the delivery of the first product code. I also made sure to advise the developers of the toolset that would be used.
Overall: I had a simple vision: automate tests in-sprint, build a pipeline, and publish results in a chart to the stakeholders. I prepared (upskilled) myself in the best way possible to get this set up in the right time. And I adopted a standard practice to automate the positive, negative, and null scenarios for each feature wherever applicable. Finally, I put my log-in scenario into a global ‘Before’ hook.?
Educating My Team On Solid Practice
Together with the developers, we standardized some best practices, which we memorialized in a document for future reference (and for onboarding purposes should any other developers join the team).?
Among the best practices we agreed on were:
There Is No "I" In Team: Asking For Help
Last but not least, I had my team to support me.?I?asked for help every time I needed the support. I felt I was heard by them and I had an awesome team lead who gave me the spotlight every time I communicated. For the first time, I felt like I could shoot webs like Spiderman. Sorry to be dramatic, let me put it this way: you don't always need superpowers to be a superwoman, just a super team to work with.
Keeping Testing In Motion While Product Code Is Written
I didn't wait around for product code to be ready. I couldn't afford to; I had a lot to do.?
Feeling The Fear And Writing Test Code Anyway?
We all know a tester's role is a niche skill. I’m not sure about all of you but I've had some challenging lows along with the rewarding highs. Thankfully, over time, I've grown far more confident to speak about the fears I've had during my career. I saw that if I worked on my fears, putting myself out there despite them, those fears turned into my strengths.?
The road to in-sprint test automation was pretty scary at times! But I processed my fears, spoke about them, turned them into action points to upskill, dealt with a few bumps, and learned from it. It was not easy but now I feel it made me stronger.?
Some of those fears follow….
And so I was challenged to create graphics and chart widgets in Azure DevOps. This is a task I never dreamt of doing. I didn't think I'd be any good at creating attractive reports on project pages, but, then again, I'd never done it before. So I figured out how to add a widget for test results on Azure Devops. In doing so, I collaborated with developers to understand what they expected from such an artifact. I tailored the widget settings in such a way that the team had some useful metrics to work from. ???????
Below, you can see the graphic produced by the widget I configured. The image was edited to hide sensitive company information. But I promise this is an original screenshot from our Cypress testing dashboard.
What We've Learned: The Good and the Oops!
As I advised my team: trial and error would show us what experiments worked and what didn't go so well. Here are some highlights.?
The joy of code review. I was terrified when I submitted my first test code for developer review in a pull request. I expected to be sent back to the drawing board entirely. That did NOT happen. What I got instead was specific and useful feedback, which led me to:?
Ready machine one. When I joined the team, I was unable to review the onboarding guide. So I delayed downloading SQL Server Management Studio. Having to wait for IT approval, then having to download, install, and configure the software while the sprint was in motion, held up my testing. Lessons learned:?
Pay attention during those Agile ceremonies. At one point, a feature was ready to test, but a potential blocker made testing impossible. I didn't help matters by waiting to ask my team for clarification. Lesson learned: I had to pay closer attention to discussions that come up during Agile ceremonies.?
To Wrap Up?
I hope this article is a good primer for establishing in-sprint test automation on your Agile team. I have found it invaluable for the entire development team to be educated on the value of in-sprint test automation (as part of a suite of shift-left testing practices). And I've learned how important it is for testers to master the art of persuading their teams to try something new and worthwhile.
To reiterate: I could not have attempted this if I had been new to Cypress or test automation,?as timeline is critical in in-sprint test automation. So if you want to incorporate in-sprint test automation and you don't yet know how to plan for it or code it, start learning how to do so now.?
Let me know your experiences in the comments. What went great? What was your biggest challenge??
For More Information
?? Read Swathika's article and others on many testing topics over at the Ministry of Testing site.
"As Head of Testing, I am responsible for the professional development of my people and have MoT Team Membership to support this. I want to have a good atmosphere and up-to-date information for the exchange. The TestBash conferences and the software testing content are excellent sources for this. Great speakers and the latest content and news from the testing community!" - Sven Schirmer
"Ministry of Testing is the one-stop shop for everything testing." - Ashutosh Mishra
Senior QA Automation Engineer | ??MOT Professional Member and ???Blogger
4 个月True joy of writing articles is when you all share similar stories and relate with mine !!
Software Quality Lead @Rabbit | ISTQB? (FL-AT-PT-ATLaS-SEC) | CTP
4 个月Thanks for sharing very realistic challenges much appreciate your ways to overcome ????
Senior Test Manager
4 个月Greatly articulated with the real time scenario. I had one such experience when I was working as a Test Manager where my testers spread across 12 cross functional scrum team running on SAFe model with 2 weeks sprint. The scenario was like this, we were successfully running N-1 sprint automation with Protractor E2E along with Jasmine BDD for two successful years. And then, we took a step forward collectively as team (along with customer) we wanted to try in-sprint automation for a couple of sprint and it really worked without major hurdles. Noticed major factors supported us - 1. Culture change as a team 2. Team should not panic if they can only deliver the shippable product on a last day of sprint 3. CI-CD enabled to support shift left testing 4. Continuous support from Development team and Business team
Creativist ?? breaking & fixing stuff. QA Enthusiast, founder @Quality Assurance Lietuva
4 个月Wow! It was such an amazing read. I was rooting for your success through the article. Thanks for sharing!
Senior QA Automation Engineer | ??MOT Professional Member and ???Blogger
4 个月Thanks for sharing Ministry of Testing