Indeed, even before the command of agile techniques like Scrum, we realized we ought to automate our tests. In any case, we didn't. Automated tests were viewed as costly to compose and were frequently composed months, or now and again years, after an element had been customized. One reason that the team thought it was hard to compose tests sooner was on the grounds that they were computerizing at some unacceptable level. A compelling test automation system calls for robotizing tests at three distinct levels, as appeared in the figure underneath, which portrays the test automation pyramid.
At the base of the test automation pyramid is unit testing. Unit testing should be the establishment of a strong test automation technique and as such speaks to the biggest piece of the pyramid. Automated unit tests are awesome in light of the fact that they give explicit information to a software engineer—there is a bug and it's on line 35. Software engineers have discovered that the bug may truly be on line 61 or 52, however it's a lot more pleasant to have an automated unit test thin it down than it is to have a tester state, "There's a bug by they way you're recovering part records from the information base," which may speak to at least 1,000 lines of code. Likewise, on the grounds that unit tests are generally written in a similar language as the framework, developers are frequently most open to keeping in touch with them. We should skip for a second the center of the test automation pyramid and bounce right to the top: the user interface level.
Automated user interface testing is set at the highest point of the test automation pyramid since we need to do as meager of it as could be expected under the circumstances. Assume we wish to test a basic number cruncher that permits a user to enter two numbers, click either a duplicate or separation catch, and afterward observe the consequence of that activity. To test this through the user interface, we would script a progression of tests to drive the user interface, type the proper qualities into the fields, press the increase or separation catch, and afterward analyze expected and real qualities. Testing thusly would surely work yet would be weak, costly, and tedious. Furthermore, testing an application this way is incompletely redundant—consider how frequently a set-up of tests like this will test the user interface. Each test case will conjure the code that associates the increase or gap catch to the code in the guts of the application that figures it out. Each test case will likewise test the code that showcases results. Etc. Testing through the user interface like this is costly and should be limited. In spite of the fact that there are many test cases that should be summoned, not all should be gone through the user interface. Furthermore, this is the place where the service layer of the test automation pyramid comes in. Albeit I allude to the center layer of the test automation pyramid as the service layer, I am not limiting us to utilizing just a service-oriented architecture.
All applications are comprised of different services. In the manner we are utilizing it, a service is something the application does because of some information or set of data sources. Our model adding machine includes two services: multiply and divide. Service-level testing is tied in with testing the services of an application independently from its user interface. So as opposed to running twelve or so multiplication test cases through the mini-computer's user interface, we rather play out those tests at the service level. Where numerous associations have turned out badly in their test automation endeavors throughout the years has been in disregarding this entire center layer of service testing. Albeit automated unit testing is great, it can cover just such an extensive amount an application's testing needs. Without service-level testing to fill the hole among unit and user interface testing, all other testing winds up being performed through the user interface, bringing about tests that are costly to run, costly to compose, and weak.
