Agile Testing Framework - The Art of Automated Testing

  • 2,559 views
Uploaded on

Once your organization has successfully implemented Agile methodologies, there are two major areas that will require improvements: Continuous Integration and Automated Testing. …

Once your organization has successfully implemented Agile methodologies, there are two major areas that will require improvements: Continuous Integration and Automated Testing.

This presentation illustrates why it's important to invest in an Automated Testing Framework (ATF) to reduce technical debt, increase quality and accelerate time to market.

Learn more at www.agiletestingframework.com.

More in: Technology
  • Full Name Full Name Comment goes here.
    Are you sure you want to
    Your message goes here
    Be the first to comment
No Downloads

Views

Total Views
2,559
On Slideshare
0
From Embeds
0
Number of Embeds
6

Actions

Shares
Downloads
186
Comments
0
Likes
12

Embeds 0

No embeds

Report content

Flagged as inappropriate Flag as inappropriate
Flag as inappropriate

Select your reason for flagging this presentation as inappropriate.

Cancel
    No notes for slide

Transcript

  • 1. Agile Testing Framework The Art of Automated Testing
  • 2. Agile Coach ● Finance: American Express, Charles Schwab, Morgan Stanley, Bank of America ● Healthcare: Mayo Clinic, Phoenix Children's Hospital, Wolters Kluwer ● Hospitality: Choice Hotels International, SkyTouch Technology ● Software: JDA Software Group, Apriva Mobile ● Security: LifeLock ● Energy: First Solar ● State of Arizona - First Things First, ADOT, ADE ● Insurance: AAA Insurance Facilitator of “The 7 Habits of Highly Effective People” Certifications ● Project Management Professional (PMP) ● Agile Certified Practitioner (PMI-ACP) ● Certified ScrumMaster (CSM) ● Certified Scrum Practitioner (CSP) IT Professional ● CIO - Concord Servicing Corporation Software ● Vice President Communications - PMI Phoenix ● Director of Web Technologies - I-ology www.AgileTestingFramework.com About Dimitri Ponomareff www.linkedin.com/in/dimka5
  • 3. Agenda ● Agile Methodologies ● Agile Testing Quadrant ● Quality ● Technical Debt ● The Testing Pyramid ● Driven Development ○ FDD ○ TDD ○ BDD ● Agile Testing Framework www.AgileTestingFramework.com
  • 4. Agile Methodologies www.AgileTestingFramework.com
  • 5. The Triple Constraint Waterfall Predictive Process Plan Driven The plan creates cost and schedule estimates Constraints Estimates Scope (requirements) Cost Time Agile Adaptive Process Cost Time Value Driven Scope (features) The vision creates feature estimates When it doesn’t fit in Agile, we cut Scope, not Quality! www.AgileTestingFramework.com
  • 6. 5 Levels of Agile Planning www.AgileTestingFramework.com
  • 7. Agile Testing Touch Points ● Release Planning ○ Document dependencies ○ Write - End to end flow tests ○ Write - Workflow tests ○ Write - Integration tests ○ ● Release Testing ○ Run - End to end flow tests ○ Run - Workflow tests ○ Run - Integration tests ○ Run - Performance and security tests ● Iteration Planning ○ Review - Acceptance criteria ● Iteration Testing ○ Write/Run - Acceptance tests ○ Write/Run - Unit tests ○ Write/Run - Component tests www.AgileTestingFramework.com
  • 8. Agile Testing Quadrant Business Facing Are we building the right product? Are we building the product right? Technology Facing www.AgileTestingFramework.com
  • 9. Agile Testing Quadrant Functional, Story & Prototype Testing Unit & Component Testing Business Facing Exploratory & Usability Testing Performance, Load & Security Testing Technology Facing Critique Product Supporting the Team www.AgileTestingFramework.com
  • 10. Agile Quality QA is no longer the Sole Quality Gatekeeper! ● QA may play new role ● Agile Quality requires new skills ● Focuses on Prevention instead of Detection ● Testing role may be done by others ● Testing done upfront ● Automation plays a bigger role ● Focuses on xUnit testing www.AgileTestingFramework.com
  • 11. Up front testing leads to lower costs and better quality www.AgileTestingFramework.com
  • 12. Quality focus on Test first vs. Test last Performance Testing Functional Testing Continuous Integration TTeesstt FFiirrsstt Test First Refactoring www.AgileTestingFramework.com
  • 13. The whole team is responsible for quality Business ● Product Owners / Product Manager ● Subject Matter Experts Technology ● Architects ● Database Administrators ● User Experience Designers ● Operations/Support team members Team ● Developers ● Testers ● Business Analysts www.AgileTestingFramework.com
  • 14. Technical Debt Is incurred by not developing in the correct way... Like Financial Debt - is dangerous if the incurred interest and the debt itself are not payed... www.AgileTestingFramework.com
  • 15. Technical Debt Two ways of doing things! Clean and smart way - takes longer to implement but makes change easier in the future Quick and dirty way - get your features sooner, but make the future changes very hard www.AgileTestingFramework.com
  • 16. Technical Debt “Shipping first time code is like going into debt. A little debt speeds development so long as it is paid back promptly with a rewrite... The danger occurs when the debt is not repaid. Every minute spent on not-quite- right code counts as interest on that debt.” Ward Cunningham (1992-03-26). "The WyCash Portfolio Management System". http://blog.techdebt.org/interviews/156/interview-with-philippe-kruchten-on-technical-debt-rup-ubc-decision-process-architecture www.AgileTestingFramework.com
  • 17. Symptoms of Technical Debt ● Loss of Productivity ● Increase in Testing ● Postponed Releases ● Code Duplication ● Low Code Coverage ● Increase in Bugs ● Unreadable Code ● Decreased Velocity ● Using Old Libraries ● Heavy Stress on Approaching Deadlines ● Being Scared of Changing Anything ● Evil Hacks Wrong Design ● Wrong Choice of Technology www.AgileTestingFramework.com
  • 18. Fixing the Technical Debt Continuous inspection with SonarQube Managing 7 axes of code quality or preventing the Developers' 7 Deadly Sins 1. Potential Bugs 2. No Coding Standards 3. Duplications 4. Lack of Unit Tests 5. Bad Distribution of Complexity 6. Spaghetti Design 7. Not Enough or Too Many Comments Strategic Design 1. Strategic debt intentionally accumulated in a project. 2. Conscious, proactive decisions with larger short term benefits. 3. Focuses on architectural and/or business trade-offs. 4. Forgo’s extensive architecture for increased speed to market or reduced overhead Agile Engineering Practices Pair Programming, TDD, Continuous Integration, Automated Unit Tests, Automated Functional Tests, Automated Other Tests(Regression), Refactoring, Clear Definition of Done www.AgileTestingFramework.com
  • 19. The Testing Pyramid Traditional Agile Source: http://www.slideshare.net/nashjain/inverting-the-testing-pyramid www.AgileTestingFramework.com
  • 20. The DDs... FDD FEATURE Driven Development TDD TEST Driven Development BDD BEHAVIOR Driven Development www.AgileTestingFramework.com
  • 21. FDD - Feature Driven Development ● Is a client-centric, architecture-centric, and pragmatic software process ● Feature Breakdown Structure (FBS) instead of WBS ● A feature is a small, client-valued function expressed in the form: <action> the <result> by/for/of/to a <object> www.AgileTestingFramework.com
  • 22. TDD - Test Driven Development Is a rapid cycle of testing, coding, and refactoring ● Relies on a very short development cycle ● Developer writes automated test case first ● Test case defines desired improvement or new function ● Next develops minimum amount of code to pass test ● Lastly refactors the new code to acceptable standards Code refactoring is a "disciplined technique for restructuring an existing body of code, altering its internal structure without changing its external behavior" www.AgileTestingFramework.com
  • 23. BDD - Behavior Driven Development ● Outside-in and pull-based - Wire-frame > Test Cases > Coding ● Multiple-stakeholder, multiple-scale, high-automation ● Describes a cycle of interactions with well-defined outputs ● Results in the delivery of working, tested software that matters www.AgileTestingFramework.com
  • 24. TDD, BDD and automated testing... BDD TDD TDD invests in automated Unit tests. BDD invests in automated Acceptance tests. www.AgileTestingFramework.com
  • 25. BDD - User Story Traceability ID: 27 STORY NAME: Save a list of potential cars for later review As a: Buyer I can: Add a car to my wish list So that: I can review my top choices at a later time. Acceptance Criteria Scenario 27.1: Add a car to my wish list Given: A potential buyer is logged in And: The car is available for sale When: The ‘Add to Favorites’ option appears And: A buyer flags the car for the wish list Then: The car details are displayed in the wish list Scenario 27.2: Review list of favorite cars Given: A potential buyer is logged in Given: A potential buyer has previously picked some favorite cars’ And: A buyer clicks on “view my favorites’ When: The buyer views the wish list And: The car is still available for sale Then: The buyer can view the car summary in the wish list Story As a <role>, I can <activity>, so that <business value> Scenarios Given <context> When <event> Then <outcome> www.AgileTestingFramework.com
  • 26. Agile Testing Framework (ATF) www.AgileTestingFramework.com
  • 27. Agile Testing Framework Agile Planning Stage ● BDD Tests written in Agile Project Management Tool www.AgileTestingFramework.com
  • 28. Agile Testing Framework Agile Implementation Stage ● BDD Tests Pulled/Run ● Data Driven/Functional Tests written ● Services Tests Run ● CI process run ● Quality, Build Status, Test Results Reported www.AgileTestingFramework.com
  • 29. Agile Testing Framework Agile Regression / Release Stage ● Regression Tests - Selenium/BDD ● Performance Testing - Front End/JVM/Load ● Security Testing ● Web Accessibility Testing ● Web Consistency Testing www.AgileTestingFramework.com
  • 30. Agile Testing Framework Agile Feedback Loop ● Technical Debt Management ● Quality Metrics ● Build Status ● Code Coverage - Unit/Functional ● Test Results ● Code Reviews www.AgileTestingFramework.com
  • 31. Learn more at www.AgileTestingFramework.com
  • 32. This presentation was inspired by the work of many people and we have done our very best to attribute all authors of texts and images, and recognize any copyrights. If you think that anything in this presentation should be changed, added or removed, please contact us. http://creativecommons.org/licenses/by-nc-nd/3.0/ www.AgileTestingFramework.com