Articles

Loading

How to Build E2E Test Cases

Test Case
Author
tanthanh
Date
2020-05-28 19:22
Views
51891764

Developing end-to-end (E2E) test cases poses a substantial challenge compared to writing unit and API test cases. Blocks of code and APIs can be tested against a well-defined, limited, and predetermined set of business rules. Test-driven-development (TDD) techniques can empower developers to write relevant tests alongside their code.

Developing E2E tests requires a fully different approach. This level of testing is meant to replicate user behavior that’s interacting with many blocks of code and multiple APIs simultaneously. Below we recommend a process that will help you build accurate, effective test cases for your E2E testing regime. Note that we will not cover test scripting here, but only test case development.

Here are the four major considerations to explore:

How to Scope E2E Testing

The goal of E2E testing is to make sure that users can use your application without running into trouble. Usually, this is done by running automated E2E regression tests against said application. One approach to choosing your scope could be to test every possible way users could use an application. This would certainly represent true 100% coverage. Unfortunately, it would also yield a testing codebase even larger than the product codebase, and a test runtime that is likely as long as it takes to write the build being tested.

Senior QA Engineers are often used to determining scope as well. Combining experience, knowledge of the code-base, and knowledge of the web app’s business metrics, a QA engineer can propose tests that should stop your users from encountering bugs when performing high-value actions.

Unfortunately, “should” is the weakness of this approach: biased understanding of the web app, cost, and reliance on one individual leads inevitably to bugs making their way into production.

The team should therefore instead test only how users are actually using the application. Doing so yields the optimal balance of achieving thorough test coverage without expending excessive resources or runtime or relying on an expert to predict how customers use the website.

This approach requires user data, rather than an expansive exploration of the different feature options in the application, to manage. To mine user data, you’ll need to use some form of product analytics to understand how your users currently use your application.

What Bugs to Target

E2E testing should not replace or substantially repeat the efforts of unit and API testing. Unit and API testing should test business logic. Generally, a unit test ensures that a block of code always results in the correct output variable(s) for given input variable(s). An API test ensures that for a given call, the correct response occurs.

E2E testing is meant to ensure that user interactions always work and that a user can complete a workflow successfully. E2E test validations should therefore make certain that an interaction point (button, form, page, etc) exists and can be used.

Then, they should verify that a user can move through all of these interactions and, at the end, the application returns what is expected in both the individual elements and also the result of user-initiated data transformations.

Well-built tests will also look for javascript or browser errors. If tests are written in this way, the relevant blocks of code and APIs will all be tested for functionality during the test execution.

Which User Flows to Follow

The risk of a bloated test suite, beyond high maintenance cost, is the runtime that grows too long for tests to be run in the deployment process for each build. If you keep runtimes to only a few minutes, you can test every build and provide developers immediate feedback about what they may have broken, so they can rapidly fix the bug.

To prevent test suite bloat, we suggest splitting your test cases into two groups: core and edge. Core test cases are meant to reflect your core features—what people are doing repeatedly. These are usually associated with revenue or bulk usability; a significant number of users are doing them, so if they fail you’re in trouble. Edge cases are the ways that people use the application that are unexpected, unintended, or rare, but might still break the application in an important way.

The testing team will need to pick and choose which of these cases to include based on business value. It’s important to be careful of writing edge case tests for every edge bug that occurs. Endlessly playing “whack a mole” can again cause the edge test suite to become bloated and excessively resource-intensive to maintain.

If runtime allows, we recommend running your core and edge tests with every build. Failing that, we recommend running core feature tests with every build, and running the longer-runtime edge case tests occasionally, in order to provide feedback on edge case bugs at a reasonable frequency.

How to Design Test Cases

Every test case, whether it is core or edge, should focus on a full and substantial user experience. At the end of a passing test, you should be certain that the user will have completed a given task to their satisfaction.

Each test will be a series of interactions, with an element on the page: a link, a button, a form, a drawing element, etc. For each element, the test should validate that it exists and that it can be interacted with. Between interactions, the test writer should look for meaningful changes in the application on the DOM that indicate whether or not the application has responded in the accepted way.

Finally, the data in the test (an address, a product selected, some other string or variable entered into the test) should be used to ensure that the test transforms or returns that data in the way that it’s expected to.

If you build E2E test cases with this process in mind, you will achieve high-fidelity continuous testing of your application without pouring unnecessary or marginally-valuable hours into maintaining the suite. You will be able to affordably ensure that users can use your application in the way they intend to do so.

Written by Dan Widing, Co-founder and CEO of ProdPerfect

Total 1

  • 2021-01-06 20:58

    Thanks for the article authors. Refer to the tester course here: https://testerprovn.com/


Total 20,613
Number Title Author Date Votes Views
20613
SileniusStor is specialized in reselling Cheap Aquafadas software online.
Softwareces | 2022.09.15 | Votes 0 | Views 50809001
Softwareces 2022.09.15 0 50809001
20612
CSStore is specialized in reselling Cheap Steinberg software online.
Softwareces | 2022.09.04 | Votes 0 | Views 50803284
Softwareces 2022.09.04 0 50803284
20611
Software Tester Community Website
ItSeTsQtBer | 2021.04.11 | Votes 0 | Views 51204003
ItSeTsQtBer 2021.04.11 0 51204003
20610
SoapUI Certification Course Content
Steveskok | 2021.02.08 | Votes 0 | Views 51481679
Steveskok 2021.02.08 0 51481679
20609
JavaScript Course Content
Steveskok | 2021.02.08 | Votes 0 | Views 50996277
Steveskok 2021.02.08 0 50996277
20608
Why most mobile testing is not continuous?
(TestExpert) | 2021.02.04 | Votes 0 | Views 51842110
(TestExpert) 2021.02.04 0 51842110
20607
8 Common Mistakes When Planning and Documenting Your Tests
(TestExpert) | 2021.02.04 | Votes 0 | Views 52879054
(TestExpert) 2021.02.04 0 52879054
20606
Types of Performance Testing
Jamessmith | 2021.01.17 | Votes 0 | Views 51815071
Jamessmith 2021.01.17 0 51815071
20605
How to Build E2E Test Cases (1)
tanthanh | 2020.05.28 | Votes 0 | Views 51891764
tanthanh 2020.05.28 0 51891764
20604
[White Paper] Delivering better software using Test Automation
tanthanh | 2020.05.28 | Votes 0 | Views 51573799
tanthanh 2020.05.28 0 51573799
20603
[Whitepaper] How to choose the right API Testing Solution
tanthanh | 2020.05.28 | Votes 0 | Views 51318071
tanthanh 2020.05.28 0 51318071
20602
[Whitepaper] How to choose the right API Testing Solution
tanthanh | 2020.05.28 | Votes 0 | Views 51078815
tanthanh 2020.05.28 0 51078815
20601
TestOps Introduction
VTB | 2020.03.23 | Votes 0 | Views 50703688
VTB 2020.03.23 0 50703688
20600
TestOps Implementation Case Study
VTB | 2020.03.23 | Votes 0 | Views 51786126
VTB 2020.03.23 0 51786126
20599
Selenium Automation Tester Certification Sample Exam Set 3
(TestExpert) | 2020.02.03 | Votes 0 | Views 52062834
(TestExpert) 2020.02.03 0 52062834
20598
Selenium Automation Tester Certification Sample Exam Set 2
(TestExpert) | 2020.02.03 | Votes 0 | Views 51929723
(TestExpert) 2020.02.03 0 51929723
20597
Selenium Automation Tester Certification : Sample Exam Set 1
(TestExpert) | 2020.02.03 | Votes 0 | Views 51329178
(TestExpert) 2020.02.03 0 51329178
20596
What is agile testing? why is agile testing? and what is the benefits? (20)
oishichip | 2019.12.26 | Votes 0 | Views 50438235
oishichip 2019.12.26 0 50438235
20595
Crowd Testing — Vantagens para testadores, plataformas e clientes [pt-br]
soikmd2 | 2019.12.14 | Votes 0 | Views 50773974
soikmd2 2019.12.14 0 50773974
20594
Software Testing Industry Report (Turkey) 2018-2019 (2)
ItSeTsQtB | 2019.08.08 | Votes 0 | Views 51670956
ItSeTsQtB 2019.08.08 0 51670956
20593
How to bypass security in integration tests in ASP.Net Core
ItSeTsQtB | 2019.08.08 | Votes 0 | Views 52794475
ItSeTsQtB 2019.08.08 0 52794475
20592
For agile testing, fail fast with test impact analysis
ItSeTsQtB | 2019.08.08 | Votes 0 | Views 52106713
ItSeTsQtB 2019.08.08 0 52106713
20591
Career Path in Software Testing
^Software^ | 2019.07.28 | Votes 0 | Views 51859156
^Software^ 2019.07.28 0 51859156
20590
Challenges in Big Data Testing
^Software^ | 2019.07.22 | Votes 0 | Views 51672945
^Software^ 2019.07.22 0 51672945
20589
Essential Necessities In Big Data Testing
^Software^ | 2019.07.22 | Votes 0 | Views 50671102
^Software^ 2019.07.22 0 50671102
20588
5 Test Data Generation Techniques
^Software^ | 2019.07.22 | Votes 0 | Views 51804461
^Software^ 2019.07.22 0 51804461
20587
CI and CD for ETL (Extract-Transform-Load) testing.
^Software^ | 2019.07.22 | Votes 0 | Views 51670901
^Software^ 2019.07.22 0 51670901
20586
Quest for Quality Conference : 5-6 Nov 2019 at Dublin, Ireland
VTB | 2019.07.08 | Votes 0 | Views 51458646
VTB 2019.07.08 0 51458646
20585
TestBash Essentials Conference 2019
VTB | 2019.07.08 | Votes 0 | Views 51367414
VTB 2019.07.08 0 51367414
20584
UKSTAR Conference : 11-03-2019
VTB | 2019.07.08 | Votes 0 | Views 50909980
VTB 2019.07.08 0 50909980
20583
Testing in Context Conference Australia (TiCCA) 2019
VTB | 2019.07.08 | Votes 0 | Views 50933376
VTB 2019.07.08 0 50933376
20582
European Testing Conference 2019
VTB | 2019.07.08 | Votes 0 | Views 51346875
VTB 2019.07.08 0 51346875
20581
Automation Guild Online Conference 2019
VTB | 2019.07.08 | Votes 0 | Views 52563434
VTB 2019.07.08 0 52563434
20580
Software Quality Days 2019 : 15 Jan 2019 (1)
VTB | 2019.07.08 | Votes 0 | Views 51725366
VTB 2019.07.08 0 51725366
20579
Skills required to become a Software Tester (1)
IT-Tester | 2019.07.08 | Votes 0 | Views 51647930
IT-Tester 2019.07.08 0 51647930
20578
Automated Unit Testing with Randoop, JWalk and µJava versus Manual JUnit Testing
IT-Tester | 2019.07.08 | Votes 0 | Views 50100126
IT-Tester 2019.07.08 0 50100126
20577
Scrum Testing Guide Book (2)
IT-Tester | 2019.06.26 | Votes 0 | Views 50615584
IT-Tester 2019.06.26 0 50615584
20576
Acceptance Testing Definition in Testing vs Scrum
IT-Tester | 2019.06.26 | Votes 0 | Views 51510402
IT-Tester 2019.06.26 0 51510402
20575
User Acceptance Testing Checklist
VTB | 2019.06.20 | Votes 0 | Views 51816063
VTB 2019.06.20 0 51816063
20574
Firewalls and Types (1)
VTB | 2018.11.14 | Votes 0 | Views 50602219
VTB 2018.11.14 0 50602219
20573
Senior Test Engineer (1)
VTB | 2018.11.05 | Votes 0 | Views 51585336
VTB 2018.11.05 0 51585336
20572
Junior Test Analyst
kornadian2 | 2018.11.04 | Votes 0 | Views 51598149
kornadian2 2018.11.04 0 51598149
20571
Senior Test Engineer
kornadian2 | 2018.11.04 | Votes 0 | Views 50880935
kornadian2 2018.11.04 0 50880935
20570
Programme Test Manager, 12m, Immed Start, $NEG
kornadian2 | 2018.11.04 | Votes 0 | Views 52857831
kornadian2 2018.11.04 0 52857831
20569
Junior Test Analyst
kornadian2 | 2018.11.04 | Votes 0 | Views 51643945
kornadian2 2018.11.04 0 51643945
20568
Dev & Test Manager
kornadian2 | 2018.11.04 | Votes 0 | Views 52431957
kornadian2 2018.11.04 0 52431957
20567
Senior Test Analyst (Performance Tester)
kornadian2 | 2018.11.04 | Votes 0 | Views 52156448
kornadian2 2018.11.04 0 52156448
20566
QA Automation Test Analyst
kornadian2 | 2018.11.04 | Votes 0 | Views 51127471
kornadian2 2018.11.04 0 51127471
20565
Software/Field Testing Engineer
kornadian2 | 2018.11.04 | Votes 0 | Views 51069160
kornadian2 2018.11.04 0 51069160
20564
Compliance Technician (Tester)
kornadian2 | 2018.11.04 | Votes 0 | Views 50920361
kornadian2 2018.11.04 0 50920361