Automatisch testen is hét buzzword als je het over Agile-testing hebt. Maar wat houdt automatisch testen eigenlijk in? En maakt het ons als testers overbodig?
Agile is voor softwareontwikkelaars een belangrijke methodiek. Het houdt in dat je in sprints een product oplevert. Aan het einde van elke sprint geldt klaar is klaar en het product kan zonder verdere controles of tests naar productie. Maar waar is testen dan gebleven in het proces? Binnen Agile zijn alle teamleden 'developer'. Er zitten dus geen testers in het team. Bovendien, zoveel tijd is er nou ook weer niet voor testen…
Automatisch testen is het antwoord?
Vraag een softwareontwikkelaar om dezelfde handeling twee keer uit te voeren, en hij vindt wel een manier om die handeling te automatiseren. Dat scheelt tijd en frustratie. Het automatiseren van testen lijkt dan ook voor de hand te liggen. Want testen - met name regressietesten - is vaak een tijdrovend klusje met veel repetitieve handelingen en controles.
En werk je in sprints van een of twee weken, dan is er vaak niet de tijd of gelegenheid om op die manier een test uit te voeren. Vooral bij Agile-teams - en zeker ook in DevOps-omgevingen - wordt daarom vaak gekozen voor automatisch testen.
Automatisch testen is het automatisch laten uitvoeren van tests. Hiervoor gebruik je speciale software die specifiek voor testen is. Automatiseren kan voor alle soorten tests, maar naarmate je verder in het proces komt, moet je meer handmatig werken. Unittesten en integratietesten zijn vaak automatisch, maar complexe systeem- en acceptatietesten vergen meer handwerk. En dat geldt zeker voor gebruikersacceptatietesten!
Verschillende automatische testtools
Je kunt testen automatiseren op verschillende manieren. En vrijwel alle testen zijn geheel of deels te automatiseren, zoals het uitvoeren van calculaties, het sturen van berichten of het invullen van een webformulier. Er zijn tools die werken door het opnemen van handelingen, zodat deze later weer afgespeeld kunnen worden (onder andere Selenium en Microsoft Test Manager kunnen op die manier werken). Er zijn ook tools die werken op basis van visuele identificatie van elementen (Sikuli). Daarnaast is het mogelijk om functionele acties (het klikken op een knopje op een website of het openen van een app op een telefoon) helemaal in code te automatiseren (Selenium, Espresso, Cucumber, Calabash).
Dit zijn allemaal variaties binnen automatisch testen. De initiële investering (van tijd) is vaak groter dan bij handmatig testen, maar doordat herhalingen minder tijd kosten, is er over langere tijd winst te behalen. Die winst is niet alleen uit te drukken in tijd, maar ook in vertrouwen van de klant (product owner en/of stakeholders) in de applicatie, omdat deze in productie waarschijnlijk minder fouten/regressie bevat. En ja, dat klinkt allemaal erg positief. En wat ook positief is: ontwikkelaars kunnen het automatisch testen zelf in gang zetten, omdat het vooral software en code behelst. Dus waarom zouden we eigenlijk überhaupt nog een tester in het team opnemen? Is een softwareontwikkelaar die goed code kan schrijven en wat testtechnieken heeft geleerd niet voldoende?
De tester blijft onmisbaar
… Nou nee. Automatisch testen is niet testen. Het is een methodiek en daarmee een van de onderdelen binnen het kwaliteitsproces. Het is het automatisch controleren van de resultaten van een set aan handelingen, nadat de software is opgeleverd. Het is code, een extra product, en daarmee een extra point of failure in de oplevering die weer zijn eigen bugs en problemen kan bevatten. De tests moeten goed doordacht zijn, voordat ze geschreven worden.
En dat is juist de kracht van de tester. Testers zijn bij het hele ontwikkelproces betrokken, vanaf de specificatie tot de oplevering. De tester kan vanuit zijn eigen kwaliteiten, kennis en ervaring kritisch kijken naar iedere fase van het project, en daar tests voor schrijven. Het testproces wordt daardoor niet uit het oog verloren. De tester zorgt er samen met het ontwikkelteam voor dat de opdrachtgever krijgt wat hij nodig heeft. Juist de andere manier van kijken van de tester maakt hem/haar een waardevol lid van het team. En (dus) waardevol voor de opdrachtgever.
Voor verdere verdieping over dit onderwerp
Automation is a Technique, Not Testing, Jeff Nyman.
The Danger of the Technocrat Tester, Jeff Nyman.
Testing and Checking Refined, James Bach & Michael Bolton.
Deliberate Testing in an Agile World: An Interview with Dan North [interview], Josiah Renaudin & Dan North.
2 april 2025 Schrijf in voor al weer de twaalfde editie van ons jaarlijkse congres met wederom een ijzersterke sprekers line-up. Op deze editie behandelen wij belangrijke thema’s als Moderne Cloud Data Architecturen, Datawarehouse Design met Ge...
3 april 2025 (halve dag)Praktische workshop met Alec Sharp [Halve dag] Deze workshop door Alec Sharp introduceert conceptmodellering vanuit een non-technisch perspectief. Alec geeft tips en richtlijnen voor de analist, en verkent datamodellering op c...
7 t/m 9 april 2025Praktische workshop met internationaal gerenommeerde spreker Alec Sharp over het modelleren met Entity-Relationship vanuit business perspectief. De workshop wordt ondersteund met praktijkvoorbeelden en duidelijke, herbruikbare richt...
10, 11 en 14 april 2025Praktische driedaagse workshop met internationaal gerenommeerde spreker Alec Sharp over herkennen, beschrijven en ontwerpen van business processen. De workshop wordt ondersteund met praktijkvoorbeelden en duidelijke, herbruikba...
20 en 21 mei 2025 Deze workshop behandelt de implementatie van Knowledge Graphs en Large Language Models binnen organisaties en biedt een uitgebreid raamwerk waarin geavanceerde technieken worden gecombineerd met praktijkcases en oefeningen. Het vo...
22 mei 2025 Workshop met BPM-specialist Christian Gijsels over AI-Gedreven Business Analyse met ChatGPT. Kunstmatige Intelligentie, ongetwijfeld een van de meest baanbrekende technologieën tot nu toe, opent nieuwe deuren voor analisten met innovatie...
2 t/m 4 juni 2025 De DAMA DMBoK2 beschrijft 11 disciplines van Data Management, waarbij Data Governance centraal staat. De Certified Data Management Professional (CDMP) certificatie biedt een traject voor het inleidende niveau (Associate) tot en me...
Alleen als In-house beschikbaarWorkshop met BPM-specialist Christian Gijsels over business analyse, modelleren en simuleren met de nieuwste release van Sparx Systems' Enterprise Architect, versie 16.Intensieve cursus waarin de belangrijkste basisfunc...
Deel dit bericht