ShowPo is a fast-moving midsize fashion eCommerce company which has been replatforming every 2 to 3 years as their business grows. To monitor and manage the stability of their website, they create a regression test suite at each replatforming. In the attached document, I outline a good cross-section of what I think would be how they test reliability and functionality, as well as dip my toes into the other elements of testing.
This piece is not a complete set of the tests that would be included in their regression test suite. I don’t cover all negative test cases, and I have only included customer-facing functions. However, I hope to provide a good cross-section which demonstrates to you how I think as a tester. While automated tests don’t test everything, the aim of a good regression test suite is to give confidence that the program works as it should.
Risk-Based Testing ShowPo - Product Risk Patterns in eCommerce
I’ve been following ShowPo since 2011. Showpo is a local Sydney company which has grown to become one of Australia’s leading fashion companies and eCommerce properties. To me, they look like the perfect case study to use as an example of how I can apply my software testing skills to any eCommerce product. I used recent articles and BuiltWith to gain an understanding of their technology stack, and help me decide which tools might be the most appropriate for them to use. I am making the assumption that ShowPo uses the agile approach to software development, based on interviews given by the founder. In writing up this case study, I opted not to talk to anyone at ShowPo. It is based purely on my experience of their site and of eCommerce itself. In a previous life, I worked as an eCommerce coordinator where I first developed skills in user acceptance testing, exploratory testing, and ad-hoc testing. As part of my self-study for my testing career I am learning the other forms of testing and how to apply them. I do a general overview of some of them here.
With this case study I aim to answer, ‘what would you test?’ and ‘how would you test it?’ during the relaunch of an eCommerce site to create a master test plan - a regression test suite used throughout the life of an eCommerce company’s use of a platform before they move onto more something suitable for their next stage of growth. It is created in the scoping out and diagramming requirements part of the initial sprint, in the very earliest stages of the Agile Software Development Life Cycle. This would place ShowPo at at least TMMi Level 3.
DISCLAIMER: This piece is not a complete set of the tests that would be included in their regression test suite. I don’t cover all negative tests, and I have only included customer-facing functions. However, I hope to provide a good cross-section which demonstrates to you how I think as a tester.
Using my personal knowledge of the eCommerce domain, I aimed to write comprehensive functional test cases.
My goal was to follow the 80/20 rule, with 80% of the test scenarios covering failure cases, and 20% covering success cases. I started with the happy path, then wrote negative tests. To find these cases first I explored boundary/range testing, and null testing. I run 1 E2E test for the happy path of each user journey.. Of course, there are also edge cases, where a non-typical customer will enter data that should be accepted, but often isn’t. These assumptions about users, through testing mostly the happy path of user experience, can negatively impact UX, usability, and accessibility. As well as these edge cases, I also explored whether ShowPo had catered for empty states, where content had not yet been added or could not yet be found but a blank state would look rough and unprofessional. Additionally, I tested a few user expectations and claims in the Help & Contact section.
Generally, only custom code added on-top of framework generated code needs testing, except in the cases where the core behaviour is changed, and I aim for the test cases i have written to reflect that.
Having BDD feature files is a good fit for ShowPo. It creates readable test-like documents that all stakeholders can understand. However, I have used plain english to for most of 'how to test' below. BDD is generally written before the code, and it is used to reduce confusion - important to reduce the overhead of constant calls and messages when we will all be working remotely for the next few years.
I used a risk-based testing strategy, keeping in mind ShowPo's rapid deadlines. Higher-priority risks to add automated tests for first are at the start, lower-priority tests towards the end.
- Unit tests
- Integration tests
- E2E tests
Linux Ubuntu 16.04 or Mac OS Catalina
This test plan targets the main user journeys. The key focus of the test plan is functionality and reliability testing - two of the six measures in ISO 9126.
- Finding outfits to choose from for a party
- Working out if the outfit can get to her in time
- Purchase items using a coupon code
- Finding out the cost of shipping before putting anything in the cart
- Looking up ShowPo policy
- Purchasing an outfit
- Saving credit card details for future purchases
- Saving home & work shipping addresses
- Creating an account for an easy way to track all ShowPo orders
- Student discounts
- Returning an item
- Purchase items using a gift card
- This test plan covers some situations that ShowPo has over the course of the year
- Planning for expansion: Soak testing
- Major sales: Stress & spike testing
Efficiency testing Maintainability testing Portability testing Usability testing Some user journeys Creating gift cards Getting notified about a product that is out of stock Admin actions
- Aside from the load and data, the test environment matches the production environment.
- Test data to check the assumptions of the tests has been added into the test environment.
- The tests are tagged by feature areas so they can be run separately during development.
- Unit tests are added to the CI/CD pipeline.
- Smoke tests are run for each commit.
- Regression tests are for each release candidate.
- Tests are run in parallel
- Issues are discovered by testers and developers.
- Defects are categorized for each product risk category by policy. They are judged by the percentage of transactions affected. Sentry data is analysed to get this information. Likelihood & Severity.
- Defects are reported to the development team through GitHub issues or JIRA.
- Defects are fixed by the developers
- Defects are verified fixed by testers
- Issue is closed
- Defect report at end of sprint
- Automated tests report
- Defects reports
Tools are chosen for each task to keep tests easier to maintain, and easier to write. Ad-hoc and exploratory testing would happen during the development phase. To view the test automation framework please see the appendix.
As a fast moving company that does replatform every 2 to 3 years as they grow, automating testing where sensible enables them to move faster, while keeping a firm check on stability. Tests that are simpler and take a shorter amount of time to write are preferred, as with all elements of the testing process.
- Junit for unit tests
- Selenium for e2e tests, using the Page Object Model
- Applitools & BrowserStack for visual testing and cross browser testing
- Axe for automated tested, and Pa11y-dashboard for first-pass accessibility auditing
- Postman for API testing, and search/list type functionality
- Salesforce recommends using Selenium server for what they define as unit tests, and Webdriver for multiple browser and headless testing, where the user interface is not required. They also recommend Mocha for the test framework.
- Many of the core features will have had system tests already written by Salesforce in the development of the platform.
For reliability testing, use a combination of testing and monitoring.
- Google Analytics for monitoring what browsers + device combinations to test
- Datadog for instrumentation
- Sentry for application monitoring and real-time error tracking
- Gatling/Flood/k6 for load testing
To briefly touch on one of the other elements of software testing
- Linting, for example prettier, can assist in testing one of the smaller aspects of code maintainability
Taking the PRISMA method, product risks are below. Risky features can be defined by the potential loss of income and reputation if they should fail. Features which are less crucial, but are nonetheless highly complex, are also risky, but carry less priority in a risk matric Areas that are changed frequently with time pressures like promotions, are also risky. Another way that I used to see what the company considered most risky was to look at what features were prioritised in the header navbar, particularly on mobile view, as these are the features found to be most important to customers outside the obvious after 8 years of conversation and monitoring.
- Payments
- Cart
- Checkout
- Transactional email
- Internationalisation
- Catalog search
- Log in / Log out / Sign up
- Returns
- Order tracking
- Contact form
- Help Centre
- Promotions
- Shipping times check
- Wishlist
- Mailing list form
- Search
- Create account
- Blog
- Edits
- Size Guide
- Issues with the test environment. Could indicate other issues.
- The number of non-reproducible functional defects for P1 product features is above 2.
- The number of critical defects.