- Inleiding tot het begrip linksverschuiving
- Wat is Shift Left Testing?
- Hoe beïnvloedt Shift Left de ontwikkeling van software?
- Wat moeten testers anders doen in Shift Left?
- Voordelen van Shift Left Testing
- Conclusie
- Aanbevolen lectuur
Het concept van Software testen werd geleidelijk ingevoerd toen defecten uit de productie het budget van het project begonnen te raken en dus werd 'Functioneel Testen' ingevoerd met een zeer slank team van Testers. Op dat moment waren we met slechts twee Testers tegen een team van 20 Ontwikkelaars.
De IT-industrie begon met het volgen van het watervalmodel voor softwareontwikkeling waarin, zoals we allemaal weten, de levenscyclus van softwareontwikkeling opeenvolgend verloopt in de volgorde van .
Dus, als je van links naar rechts gaat, is de Testfase uiterst rechts van de levenscyclus van de softwareontwikkeling.
Inleiding tot het begrip linksverschuiving
Na verloop van tijd besefte men het belang van Software testen en de impact van het houden van de "Testfase" uiterst rechts of aan het eind van de Software Development Lifecycle. Deze realisatie gebeurde omdat de kosten van de bug die uiterst rechts en aan het eind werd geïdentificeerd zeer hoog waren en een enorme inspanning & te veel tijd vergde om ze op te lossen.
Er waren gevallen waarin, na zoveel tijd en moeite aan software te hebben besteed, de bedrijfskritische software niet op de markt kon worden gebracht vanwege een aan het eind geconstateerde cruciale bug, wat resulteerde in een enorm verlies.
Bijgevolg werd, vanwege de identificatie van de bug in de laatste fase, ofwel de release uitgesteld, ofwel werd de software soms geschrapt, omdat de inspanning die nodig was om de bug te verhelpen, eigenlijk niet de moeite waard was.
"Gebreken zijn minder kostbaar als ze vroegtijdig worden ontdekt.
Dit besef en de grote les die daaruit werd getrokken, veroorzaakte een grote revolutie in de software-industrie en gaf geboorte aan een nieuw concept, genaamd "Shift Left wat betekent dat de "testfase" van links naar rechts wordt verschoven of dat de testers in elke fase worden betrokken.
Shift Left testen betekent ook dat je niet aan het eind test, maar voortdurend test.
Wat is Shift Left Testing?
Ten eerste ondersteunt het beginsel van "Shift left" de Het testteam werkt vroegtijdig samen met alle belanghebbenden In de softwareontwikkelingsfase kunnen zij de eisen duidelijk begrijpen en de testgevallen ontwerpen om de software 'Fail Fast' te maken en het team in staat te stellen alle fouten zo snel mogelijk te verhelpen.
De benadering van Shift Left is niets anders dan de testers veel eerder bij de levenscyclus van de softwareontwikkeling te betrekken, waardoor zij de eisen, het softwareontwerp, de architectuur, de codering en de functionaliteit ervan kunnen begrijpen, moeilijke vragen kunnen stellen aan klanten, bedrijfsanalisten en ontwikkelaars, opheldering kunnen vragen en waar mogelijk feedback kunnen geven om het team te ondersteunen.
Door deze betrokkenheid en dit begrip zullen de testers volledige kennis opdoen over het product, verschillende scenario's doordenken, en real-time scenario's ontwerpen op basis van het gedrag van de software, wat het team zal helpen bij het opsporen van gebreken, nog voordat de codering is uitgevoerd.
Hoe beïnvloedt Shift Left de ontwikkeling van software?
Shift Lift Approach beïnvloedt de ontwikkeling van software op verschillende manieren.
Hieronder volgen enkele belangrijke punten over Shift Left:
- De aanpak van Shift Left richt zich op het betrekken van testers bij alle en vooral de kritieke fasen van het programma Hierdoor kunnen de testers hun aandacht verleggen van het opsporen van defecten naar het voorkomen van defecten en de bedrijfsdoelstellingen van het programma sturen.
- De shift Left aanpak biedt, hoog belang voor Testen waarmee de rollen en verantwoordelijkheden van de testers enorm toenemen.
- Nu de verantwoordelijkheid voor het testteam wordt vergroot, richt het team zich niet op "De software testen om de bugs te identificeren maar werkt proactief samen met het team vanaf de eerste stadia om een robuuste en effectieve teststrategie te plannen en op te bouwen door een grote Testleiding en begeleiding te geven aan het team door zich te richten op de langetermijnvisie van het product, in plaats van alleen de verantwoordelijkheid te nemen voor het testwerk.
- De Shift Left benadering geeft de gelegenheid voor de testers om eerst de tests te ontwerpen waarbij de tests volledig gericht zijn op de ervaring van de klant en zijn verwachtingen, zodat de ontwikkelaars de software op basis van deze tests kunnen ontwikkelen en zo aan de behoeften van de klant kunnen voldoen.
- De Shift Left aanpak houdt niet op bij de Testers alleen. Door de testactiviteiten continu uit te voeren en te laten uitvoeren zal ook de ontwikkelaars in staat stellen meer verantwoordelijkheid te nemen van hun code en hun verantwoordelijkheden voor het testen vergroten.
- De aanpak van de verschuiving naar links moedigt ook aan Testers voor gedragsgestuurde ontwikkeling BDD en testgestuurde ontwikkeling TDD. die helpt voorkomen dat het defect in de software terechtkomt.
- Shift Left Testing in Agile: Shift Left aanpak ondersteunt de vorming van Agile Scrum Teams met verplicht Testers samen met de andere rollen en omvat Testers in regelmatige stand-upgesprekken, andere interacties, evaluatievergaderingen waardoor de testers meer informatie hebben over het programma en dus kunnen deelnemen aan de gedetailleerde analyse van de software en snel feedback kunnen geven die helpt bij het voorkomen van gebreken in de software.
Voor het testen van Shift Left in het algemeen moeten de testers 'Word vroeg betrokken' Zo vroeg mogelijk de discussie aangaan en samenwerken aan ideeën en eisen in elke fase waarin het resultaat van de fase van invloed is op de waarde van het eindproduct, en ook het project helpen om de risico's te identificeren en vooraf te beperken.
Wat moeten testers anders doen in Shift Left?
Hieronder staan enkele belangrijke factoren die moeten worden opgemerkt als wat de Testers anders doen in Shift Left Strategy:
#1) Het testteam moet vanaf het begin van het project in een vroeg stadium bij het systeem betrekken om de integratie met de rest van het team en het bedrijf te ontwikkelen tot in elk stadium nuttige input te leveren van de softwareontwikkeling.
#2) Het testteam moet samenwerken met het Business & Operations team en duidelijkheid krijgen over het programma en bieden een duidelijk beeld van de vraag en helpen bij een efficiënte planning van de behoeften aan hulpmiddelen, opleiding en testinstrumenten voor het programma, ruim van tevoren.
#3) Testteams moeten vroeg in de softwareontwikkeling met alle zakelijke belanghebbenden samenwerken om duidelijk zicht krijgen op het product & een uniforme teststrategie ontwerpen en plan voor een geoptimaliseerde testinspanning, analyseer de afhankelijkheid van testomgevingen, derden, stubs, enz. en bereid een robuuste automatiseringsstrategie en -kader voor en bouw een effectief plan voor het beheer van testgegevens.
#4) Het testteam moet samenwerken met de rest van het team bij het verstrekken van groot testleiderschap en begeleiding van het team daarbij de productvisie op lange termijn voor ogen te houden in plaats van alleen de verantwoordelijkheid voor de testactiviteiten op zich te nemen.
#5) Requirements zijn de sleutel en de basis voor het succes van elk programma en goed gedefinieerde requirements bepalen het succes van het project. Tijdens de Requirements Planning fase, Testers moet de eisen herzien en analyseren voor onduidelijkheden, meer duidelijkheid, volledigheid, testbaarheid, definitie van acceptatiecriteria, enz.
Ook moeten de ontbrekende eisen (indien aanwezig) worden geïdentificeerd, en de afhankelijkheden en implementatiestrategieën worden begrepen. Duidelijke eisen helpen de software om 'Fail Fast' te zijn en alle fouten in een vroeg stadium op te lossen.
#6) Breng voldoende duidelijkheid en precisie in de vereisten door de echte voorbeelden die de gebruikte functies illustreren.
#7) Testers moeten vergaderingen over het ontwerp bijwonen Regelmatig het productontwerp en de architectuur begrijpen en de ontwerpfouten identificeren, alternatieve ontwerpopties voorstellen, de mazen in het ontwerp opsporen en testscenario's opstellen om de ontwerpen te doorbreken.
#8) Testers moeten Statische tests uitvoeren (beoordelingen) ruim van tevoren en geef feedback op belangrijke projectdocumenten, zodat wordt voorkomen dat gebreken in de software vastlopen en het effect ervan later groter wordt.
#9) Het testteam moet samenwerken met het ontwerp- en ontwikkelingsteam bij het vooraf verstrekken van testscenario's om de code te ontwikkelen en alle mogelijke real-time scenario's en bedrijfsstromen aanpakken.
#10) Het testteam moet ontwerpen sterke en robuuste testscenario's zodat tijdens het testen slechts enkele gebreken worden vastgesteld en grote gebreken worden voorkomen bij het ingaan van de testfase.
#11) Testers moeten Test zo vroeg mogelijk op een stand-alone of lokaal systeem, zodat het defect niet in latere stadia terechtkomt.
De hele crux van het "Shift Left"-concept voor testers is het zo vroeg mogelijk vinden van defecten met alle mogelijke middelen.
Voordelen van Shift Left Testing
De Shift Left aanpak werkt op basis van het agile manifest en heeft ook verschillende voordelen.
Dat zijn ze:
- Individuen en interacties over processen en instrumenten.
- Werkende software over uitgebreide documentatie.
- Samenwerking met de klant over contractonderhandelingen.
- Reageren op verandering over het volgen van een plan.
We zien dat de waarde van de items aan de rechterkant weliswaar aanwezig is, maar dat we meer waarde hechten aan de items aan de linkerkant.
Wel, Shift Left brengt het idee van testen eerder in het proces, waardoor het testen beter en efficiënter verloopt en de kwaliteit van de software verbetert.
In een notendop is het Shift Left Testing proces:
- De gebreken in een vroeg stadium opsporen, waardoor de kosten van het project dalen.
- Steeds opnieuw testen om uiteindelijk het aantal defecten te verminderen.
- Om alles te automatiseren en de time to market te verbeteren.
- De eisen van de klant centraal stellen en de klantervaring verbeteren.
Conclusie
De "Shift Left concept bracht een enorme transformatie voor de hele 'Testing' rol. Tot dan toe was de enige focus voor de Testing alleen gericht op 'Defect Detection', en nu is het doel van de 'Shift Left' vanuit het Testing perspectief een reis van "Vroegtijdige opsporing van defecten tot statische tests .
Shift Left is dus een grote sprong voorwaarts in de software-industrie op het gebied van softwareontwikkelingsmethodologie met het oog op een snellere marktintroductie, een betere kwaliteit van de software en een kortere "time to market".
Over de auteur: Dit artikel is geschreven door STH teamlid Gayathri Subrahmanyam zit sinds de jaren '90 in het testen van software, net toen de rol van tester werd geïntroduceerd in de industrie. Tijdens haar testcarrière heeft ze veel TMMI assessments, Test Industrialisatie werken en TCOE setups gedaan, naast het afhandelen van test opleveringen en het implementeren van DevOps praktijken voor een grote opdracht. Maar volgens haar houdt het leren nooit op...
Laat ons uw gedachten/suggesties weten in het commentaarveld hieronder.
PREV Handleiding