There's a recording of this talk at Agile 2012 here: http://www.youtube.com/watch?v=v-L_2y6g5DI
Creating automated end-to-end functional acceptance tests is hard. Maintaining them over time is harder. Some agilistas even claim that the cost outweighs the benefit. In this lecture we present five principles for creating valuable, maintainable acceptance test suites. We discuss practices such as layering acceptance tests to reduce coupling between the test harness, and talk about how teams should be organized in order to efficiently manage acceptance test driven development. The core of the talk discusses how to manage the evolution of acceptance tests by organizing them as scenarios rather than as suites of story tests. Finally we show how to manage data for acceptance tests.
Shallow Depth of Test - Test at the appropriate levelfabiopereirame
The document discusses testing at different levels including unit testing with mocks/stubs and shallow depth of test, integration testing by simulating HTTP, and UI testing of journeys. It also mentions using builders and fixtures for unit level BDD.
Acceptance testing is performed by customers or their representatives after system testing to determine if the system meets their needs and expectations. Acceptance tests execute real-life scenarios near the customer environment and have a small number of test cases intended to validate functionality, not find defects. Customers verify that the product, procedures, user documentation and service level agreements all meet acceptance criteria before the product is approved for release.
This document provides an introduction to software testing. It discusses software engineering and the software development life cycle (SDLC). The phases of the SDLC include problem definition, requirement analysis, planning, design, implementation, testing, deployment, and maintenance. Testing goals are to prevent and discover bugs. Different levels of testing include unit testing, integration testing, and system testing. The document also discusses testing concepts like the pesticide paradox, dichotomies between testing and debugging, and whether complete testing is possible.
User Acceptance Testing (UAT) involves real business users testing a system to determine if it will provide benefit and be acceptable for use in the organization. During UAT, users test the system according to test cases and document any defects found. The goal of UAT is not to prove a system works, but rather to expose faults before it goes live, as the only way to prove a system is by finding ways for it to fail testing. UAT deliverables include test cases, test results, and a defect log.
Supercharge your teams with Value Stream Management by Richard KnasterBosnia Agile
This document discusses how to supercharge teams with value stream management (VSM). It defines VSM as optimizing people, processes, and technology to continuously improve the flow of business value from ideation to customer delivery. Key aspects of VSM include organizing teams around value streams, applying lean principles like eliminating waste and improving flow, and using a value stream management platform for visibility and governance of the DevOps pipeline. The document recommends starting VSM with a value stream that has leadership support, delivers visible value, involves existing agile teams, and presents opportunities for significant improvement.
IT Quality Testing and the Defect Management ProcessYolanda Williams
This document provides an overview of defect management processes. It discusses defining defects, defect prevention, discovery, resolution and process improvement. The key aspects covered are:
- Defining goals as preventing defects, early detection, minimizing impact and process improvement.
- Activities like root cause analysis, escape analysis and process metrics.
- The defect lifecycle of prevention, discovery, resolution and continuous improvement.
- Examples of defect analysis and status reporting including metrics like density, backlog and mean time to repair.
This deck consists of total of fourty four slides. It has PPT slides highlighting important topics of Agile Delivery PowerPoint Presentation Slides. This deck comprises of amazing visuals with thoroughly researched content. Each template is well crafted and designed by our PowerPoint experts. Our designers have included all the necessary PowerPoint layouts in this deck. From icons to graphs, this PPT deck has it all. The best part is that these templates are easily customizable. Just click the DOWNLOAD button shown below. Edit the colour, text, font size, add or delete the content as per the requirement. Download this deck now and engage your audience with this ready made presentation. http://bit.ly/2Q7lImJ
The document provides an overview of CA's Unicenter Service Desk solution for implementing an IT service management framework based on ITIL best practices. It describes the key components of the solution including incident, problem, and change management modules as well as reporting and dashboard capabilities for monitoring service levels. The solution aims to standardize and automate IT service processes to improve service quality and reduce costs.
The document discusses user stories and how they can be used to improve communication between those building software and those wanting the software. It provides examples of well-structured user stories that include a template, acceptance criteria, and details on how specific and granular stories should be. Technical user stories are also discussed, which focus on non-functional requirements like infrastructure and refactoring rather than end-user functionality. The key benefits of user stories are outlined as being short and modifiable, allowing projects to be broken into small increments, and making effort estimation and development planning easier.
Agile Testing – embedding testing into agile software development lifecycle Kari Kakkonen
My presentation on Agile Testing, including a tuning concept and a case study of agile testing choices in a project, held 16 of June, 2014 at a customer internal seminar.
Este documento discute testes de contrato, incluindo: 1) o que é um contrato, 2) problemas com contratos no dia-a-dia como atualizações que quebram funcionalidades, 3) tipos de contratos como orientados ao consumidor, 4) ferramentas como Swagger e Pact, e 5) a importância de testar contratos para garantir a qualidade e compatibilidade entre serviços.
Agile requirement gathering and elicitation techniques will be explained on this presentation. It is useful for Business Analysts and Agile practioners.
The document provides an overview of agile estimating and planning techniques. It discusses agile principles like iterative development, self-organizing teams, and rapid delivery of working software. It also covers topics like writing user stories, estimating story points, calculating velocity, product backlog design, sprint planning, daily standups, and sprint reviews. The goal is to teach best practices for agile planning and estimation.
Modeling Extraneous Activity Delays in Business Process SimulationMarlon Dumas
This paper presents a technique to enhance the fidelity of business process simulation models by detecting unexplained (extraneous) delays from business process execution data, and modeling these delays in the simulation model, via timer events.
The presentation was delivered at the 4th International Conference on Process Mining (ICPM'2022).
Paper available at: https://arxiv.org/abs/2206.14051
The document discusses defect tracking and management. It provides details on defect identification, reporting, tracking, resolution and using defect information to improve processes. A recommended structure is given for defect reports, including title, description, steps to reproduce, actual and expected results. Examples of a defect report and tracking sheet in Excel are also shown. The defect management process involves executing tests, logging discrepancies, reviewing with developers, assigning defects, retesting after fixes, and closing defects when resolved.
Requirements gathering in agile development a practical experienceStefano Rizzo
Polarion Software has adopted Scrum for their agile development process over the past 4 years. They hold two-week iterations called sprints. To plan sprints, they create user stories from various requirements sources like user feedback and strategy meetings. User stories must be atomic, self-explanatory, and valuable. Creating high-quality user stories is challenging and critical for Scrum to be effective. Lessons learned are that iterations must be short, investment in product management is key, and the development team's motivation must be maintained for Scrum to provide benefits like frequent results and transparency.
The document outlines a test strategy for an agile software project. It discusses testing at each stage: release planning, sprints, a hardening sprint, and release. Key points include writing test cases during planning and sprints, different types of testing done during each phase including unit, integration, feature and system testing, retrospectives to improve, and using metrics like burn downs and defect tracking to enhance predictability. The overall strategy emphasizes testing early and often throughout development in short iterations.
This document discusses test-driven development (TDD), behavior-driven development (BDD), and acceptance test-driven development (ATDD). It explains that while they have different names, they all share the same core idea of using examples from business requirements to create automated tests. The document provides examples of how to write tests before having a user interface, and recommends abstracting from the GUI to focus on business logic. It also lists some popular tools that can be used for ATDD, BDD, and TDD.
The document discusses OSS/BSS testing and AMS from multiple perspectives. It provides an overview of OSS/BSS systems and their modules. It then discusses testing from a business perspective focusing on customer and service lifecycles, and from a technical perspective focusing on frontend and backend systems. It proposes introducing Testing as a Service (TaaS) to provide OSS/BSS testing in a flexible consumption model. It discusses leveraging testing teams and environments to serve business needs and building a testing repository for the telecom industry.
This document provides a high-level overview of key components in telecom OSS/BSS systems. It discusses general concepts like numbering plans and call scenarios. It then summarizes the main components, including data collection, mediation, billing, SS7 monitoring, revenue assurance, and fulfillment/provisioning. The document provides brief explanations of the purpose and processes within each component.
JIRA is an issue tracking tool that allows users to prioritize, assign, track, report on and audit issues. It is a customizable platform that can be used for software bugs, helpdesk tickets, user stories, change requests and other tasks. JIRA improves productivity by streamlining issue tracking and coordination, and improves quality by ensuring all tasks are fully documented and followed through to completion. It provides features like sub-tasks, versions, search capabilities, reporting, configuration options and workflows to support various use cases including service desks, project management, agile development and more.
This is a case study on conducting User Acceptance Testing (UAT) of a complex B2E software application. Involved testing of several critical HR and Payroll modules.
1) O documento discute como construir um Data Lake na AWS utilizando várias tecnologias da AWS.
2) É apresentada uma agenda com conceitos de Data Lake, simplificando o Data Lake e quais tecnologias utilizar.
3) Uma arquitetura de referência e design patterns são discutidos.
How Spotify Does Test Automation - Kristian KarlSmartBear
Kristian Karl's (@kristiankarl) presentation from MeetUI 2013, SoapUI's first user conference, in Stockholm, Sweden. Kristian is a test manager at Spotify.
Most of the people think that quality in software development is limited to manual testing on the latest stage before releasing a product. That might be true 20 years ago in the industrial era. But current world is much more dynamic than before. Time to market became the most crucial metric nowadays. Releasing code to production need to be done faster and faster. How to maintain quality on a sufficient level in this fast paced environment? How to find a time to work on quality improvements? Those are two main questions I want to answer during this talk. Do not expect a silver bullet or even receipt to success. But definitely expect a lot of information about continuous delivery/deployment/improvements with a case studies and lessons we learned at Spotify.
Spotify Engineering Culture:
https://labs.spotify.com/2014/03/27/spotify-engineering-culture-part-1/
https://labs.spotify.com/2014/09/20/spotify-engineering-culture-part-2/
Scaling Agile @ Spotify
http://blog.crisp.se/2012/11/14/henrikkniberg/scaling-agile-at-spotify
Scaled Agile @ Spotify
http://vimeo.com/111131934
The document provides an overview of CA's Unicenter Service Desk solution for implementing an IT service management framework based on ITIL best practices. It describes the key components of the solution including incident, problem, and change management modules as well as reporting and dashboard capabilities for monitoring service levels. The solution aims to standardize and automate IT service processes to improve service quality and reduce costs.
The document discusses user stories and how they can be used to improve communication between those building software and those wanting the software. It provides examples of well-structured user stories that include a template, acceptance criteria, and details on how specific and granular stories should be. Technical user stories are also discussed, which focus on non-functional requirements like infrastructure and refactoring rather than end-user functionality. The key benefits of user stories are outlined as being short and modifiable, allowing projects to be broken into small increments, and making effort estimation and development planning easier.
Agile Testing – embedding testing into agile software development lifecycle Kari Kakkonen
My presentation on Agile Testing, including a tuning concept and a case study of agile testing choices in a project, held 16 of June, 2014 at a customer internal seminar.
Este documento discute testes de contrato, incluindo: 1) o que é um contrato, 2) problemas com contratos no dia-a-dia como atualizações que quebram funcionalidades, 3) tipos de contratos como orientados ao consumidor, 4) ferramentas como Swagger e Pact, e 5) a importância de testar contratos para garantir a qualidade e compatibilidade entre serviços.
Agile requirement gathering and elicitation techniques will be explained on this presentation. It is useful for Business Analysts and Agile practioners.
The document provides an overview of agile estimating and planning techniques. It discusses agile principles like iterative development, self-organizing teams, and rapid delivery of working software. It also covers topics like writing user stories, estimating story points, calculating velocity, product backlog design, sprint planning, daily standups, and sprint reviews. The goal is to teach best practices for agile planning and estimation.
Modeling Extraneous Activity Delays in Business Process SimulationMarlon Dumas
This paper presents a technique to enhance the fidelity of business process simulation models by detecting unexplained (extraneous) delays from business process execution data, and modeling these delays in the simulation model, via timer events.
The presentation was delivered at the 4th International Conference on Process Mining (ICPM'2022).
Paper available at: https://arxiv.org/abs/2206.14051
The document discusses defect tracking and management. It provides details on defect identification, reporting, tracking, resolution and using defect information to improve processes. A recommended structure is given for defect reports, including title, description, steps to reproduce, actual and expected results. Examples of a defect report and tracking sheet in Excel are also shown. The defect management process involves executing tests, logging discrepancies, reviewing with developers, assigning defects, retesting after fixes, and closing defects when resolved.
Requirements gathering in agile development a practical experienceStefano Rizzo
Polarion Software has adopted Scrum for their agile development process over the past 4 years. They hold two-week iterations called sprints. To plan sprints, they create user stories from various requirements sources like user feedback and strategy meetings. User stories must be atomic, self-explanatory, and valuable. Creating high-quality user stories is challenging and critical for Scrum to be effective. Lessons learned are that iterations must be short, investment in product management is key, and the development team's motivation must be maintained for Scrum to provide benefits like frequent results and transparency.
The document outlines a test strategy for an agile software project. It discusses testing at each stage: release planning, sprints, a hardening sprint, and release. Key points include writing test cases during planning and sprints, different types of testing done during each phase including unit, integration, feature and system testing, retrospectives to improve, and using metrics like burn downs and defect tracking to enhance predictability. The overall strategy emphasizes testing early and often throughout development in short iterations.
This document discusses test-driven development (TDD), behavior-driven development (BDD), and acceptance test-driven development (ATDD). It explains that while they have different names, they all share the same core idea of using examples from business requirements to create automated tests. The document provides examples of how to write tests before having a user interface, and recommends abstracting from the GUI to focus on business logic. It also lists some popular tools that can be used for ATDD, BDD, and TDD.
The document discusses OSS/BSS testing and AMS from multiple perspectives. It provides an overview of OSS/BSS systems and their modules. It then discusses testing from a business perspective focusing on customer and service lifecycles, and from a technical perspective focusing on frontend and backend systems. It proposes introducing Testing as a Service (TaaS) to provide OSS/BSS testing in a flexible consumption model. It discusses leveraging testing teams and environments to serve business needs and building a testing repository for the telecom industry.
This document provides a high-level overview of key components in telecom OSS/BSS systems. It discusses general concepts like numbering plans and call scenarios. It then summarizes the main components, including data collection, mediation, billing, SS7 monitoring, revenue assurance, and fulfillment/provisioning. The document provides brief explanations of the purpose and processes within each component.
JIRA is an issue tracking tool that allows users to prioritize, assign, track, report on and audit issues. It is a customizable platform that can be used for software bugs, helpdesk tickets, user stories, change requests and other tasks. JIRA improves productivity by streamlining issue tracking and coordination, and improves quality by ensuring all tasks are fully documented and followed through to completion. It provides features like sub-tasks, versions, search capabilities, reporting, configuration options and workflows to support various use cases including service desks, project management, agile development and more.
This is a case study on conducting User Acceptance Testing (UAT) of a complex B2E software application. Involved testing of several critical HR and Payroll modules.
1) O documento discute como construir um Data Lake na AWS utilizando várias tecnologias da AWS.
2) É apresentada uma agenda com conceitos de Data Lake, simplificando o Data Lake e quais tecnologias utilizar.
3) Uma arquitetura de referência e design patterns são discutidos.
How Spotify Does Test Automation - Kristian KarlSmartBear
Kristian Karl's (@kristiankarl) presentation from MeetUI 2013, SoapUI's first user conference, in Stockholm, Sweden. Kristian is a test manager at Spotify.
Most of the people think that quality in software development is limited to manual testing on the latest stage before releasing a product. That might be true 20 years ago in the industrial era. But current world is much more dynamic than before. Time to market became the most crucial metric nowadays. Releasing code to production need to be done faster and faster. How to maintain quality on a sufficient level in this fast paced environment? How to find a time to work on quality improvements? Those are two main questions I want to answer during this talk. Do not expect a silver bullet or even receipt to success. But definitely expect a lot of information about continuous delivery/deployment/improvements with a case studies and lessons we learned at Spotify.
Spotify Engineering Culture:
https://labs.spotify.com/2014/03/27/spotify-engineering-culture-part-1/
https://labs.spotify.com/2014/09/20/spotify-engineering-culture-part-2/
Scaling Agile @ Spotify
http://blog.crisp.se/2012/11/14/henrikkniberg/scaling-agile-at-spotify
Scaled Agile @ Spotify
http://vimeo.com/111131934
Ross Snyder, Etsy, SXSW Lean Startup 2013500 Startups
1. Etsy moved from a waterfall deployment process with long development cycles and infrequent deployments to a continuous deployment model with small code changes deployed frequently by engineers.
2. Continuous deployment allows Etsy to experiment continuously and make small iterative improvements, reducing the risk of outages and allowing issues to be addressed quickly.
3. Etsy now deploys code changes over 25 times per day on average, every day, with the goal of keeping deployments fast and low-risk through techniques like feature flags and extensive monitoring.
In today’s multi-device world, eLearning needs to be accessible anytime and anywhere across all devices. Here's a compilation of tips for the development, testing and delivery of eLearning courseware.
The document discusses concepts related to continuous delivery and deployment pipelines. It advocates building quality into software through automated testing and collaboration between developers, testers and operations teams. Continuous delivery aims to make software production-ready at any time by implementing configuration management, continuous integration, and automated testing in a deployment pipeline that provides feedback at every change. This reduces risk and enables frequent, reliable releases that are tied to business needs rather than operational constraints.
This document provides an introduction and overview of using SoapUI for testing web services. It begins with background on XML, SOAP, REST, and WSDL. It then demonstrates how to create a SoapUI project from a WSDL, view and submit sample requests and responses, validate requests, and create multiple test cases. The document provides guidance on project structure, endpoints, properties, and navigating the SoapUI interface. Finally, it includes an exercise to create test cases for a weather web service.
A brief introduction to test automation covering different automation approaches, when to automate and by whom, commercial vs. open source tools, testability, and so on.
Continuous Delivery Sounds Great but it Won't Work HereJez Humble
Since the Continuous Delivery book came out in 2010, it's gone from being a controversial idea to a commonplace... until you consider that many people who say they are doing it aren't really, and there are still plenty of places that consider it crazy talk.
In this session Jez will present some of the highlights and lowlights of the past six years listening to people explain why continuous delivery won't work, and what he learned in the process.
The DORA Technology Performance Assessment provides a holistic and scientific tool to measure key outcomes and capabilities that drive improvement in software delivery performance. It benchmarks organizations against industry data to identify priority areas for capability improvement with the highest impact. The assessment measures outcomes like deploy frequency and failure rates, as well as capabilities in processes, culture, tools, and metrics. Customers report the assessment focused their efforts, accelerated maturity, and provided insights to improve performance.
This document summarizes a presentation on best practices for using Selenium for test automation. The presentation covers 12 steps: 1) Admit you have a problem; 2) Take a deep breath; 3) Try looking at things differently; 4) Pump some tech iron; 5) Find your inner Napoleon and develop a strategy; 6) Break down the wall between QA and development; 7) Learn the terrain; 8) Test less but test well; 9) Keep it lean and optimize; 10) Pay it forward by sharing knowledge; 11) Resources for learning Selenium; 12) Recap of the 12 steps. The document provides additional details on each step and recommendations for learning more.
An introduction to the concepts behind Continuous Delivery as well as an introduction to some of the tools available for implementing continuous delivery practices on a new project. This presentation is geared towards Java developers, but is applicable to all.
Testing is probably the most misunderstood concept in software engineering. Many still believe that testing is simply a verification of actual and expected results in pre-defined set of test scenarios. I wish to know earlier how wrong this statement is.
Conversations about testing can be seen wide, ambiguous, and hard to facilitate. But when done properly show prominent results.
You start from quality. Addressing questions like. What does quality mean for us? Who owns it? Who is responsible for quality improvements? There is no single answer to every team. Each has to come up with their own definition, which works in their particular situation.
Testing is not a measure for quality, but rather a set of activities and preparations to increase a level of confidence before releasing. You cannot simply state that after verifying 1000 test scenarios the whole product behaves as expected.
During this presentation I will share key findings which I think are the most important ones to get almost any engineering team on the right track towards improving productivity and released product quality. There is no single rule to rule them all, but experience-based patterns.
What is the best way to measure progress on an Agile project?ThoughtWorks Studios
The document discusses problems with using a burndown chart to measure progress on an Agile project, including that it provides unclear information, lacks visibility of scope, and can be inaccurate. It recommends instead measuring story completion by tracking what percentage of customer-valued stories are complete. An effective alternative is using a burnup chart to visualize scope changes, progress toward completion, and forecast delivery based on historical velocity.
The RTSJ (Real-Time Specification for Java) provides features for real-time Java programming like real-time threads with precise scheduling, memory management schemes like immortal and scoped memory, asynchronous event handling, nanosecond timers, and direct access to physical memory. It addresses issues in the standard Java SE like unpredictable garbage collection and enables hard real-time capabilities with latencies of 20 microseconds and jitters of 10 microseconds. The RTSJ is used in applications like real-time CORBA, Mars rovers, and medical devices.
This is a hands-on workshop that will teach you how to build a Web application that incorporate real-time communication between the client application running on the browser and the back-end server.
We will start with an overview of technologies and tools available for building real-time Web apps, what’s involved, the basics, and the gotchas. Next, we will build, in real-time, a real-time chat application using the python (Tornado) + socket.io + Backbone stack. Why not Node.js, you might ask. Simple: it’s too easy, too popular, and and not super-stable or secure. But you’re welcome to use Node.js as the backend in your own apps!
Lecture 6 from the IAG0040 Java course in TTÜ.
See the accompanying source code written during the lectures: https://github.com/angryziber/java-course
Gives an overview how a software developer should organize their daily work, apart from technical skills.
Introduces Agile software development practices from XP and Scrum.
Quality assurance in distributed continuous deliverymingjin
The document discusses quality assurance for distributed continuous delivery. It addresses challenges like testing across legacy and distributed systems. It promotes a shared responsibility between QA and developers for quality. It advocates building quality in through techniques like automated testing, functional testing at boundaries, and validating deployments. It also stresses the importance of communication, collaboration, and co-education between QA and developers.
The document discusses agile testing and how it differs from traditional testing methodologies. It outlines how agile transformations affect testing practices, requiring testers to shift from solely writing test scripts to participating in requirements definition and writing test cases earlier. It also discusses common types of agile testing like exploratory and risk-based testing. The document provides examples of open source tools that can be used for agile testing and highlights both advantages like reduced costs and faster delivery, and disadvantages like less documentation.
Agile Java Testing With Open Source FrameworksViraf Karai
This is a presentation on leveraging open-source, agile test frameworks to do unit, load/perf, integration and performance testing on Java enterprise applications.
Software Quality and Test Strategies for Ruby and Rails ApplicationsBhavin Javia
This document provides an overview of software quality and test strategies for Ruby and Rails applications. It discusses the importance of quality, managing quality through setting goals and measuring metrics. It outlines a test strategy template and covers test types, tools, and approaches for unit, integration, acceptance and other types of tests in Ruby/Rails. It also discusses test data management, defect management, and the Ruby/Rails testing ecosystem including various testing frameworks and quality/metrics tools.
Test Automation Frameworks: Assumptions, Concepts & ToolsAmit Rawat
The document discusses factors to consider when selecting a test automation framework. It describes how there are many options for frameworks available and outlines important criteria to evaluate, such as flexibility, ability to support different applications and interfaces, tool and language independence, parallel execution, and design patterns. The presentation provides examples of different types of frameworks and discusses strategies for building frameworks that can scale and evolve with changing needs.
Rahul Anand is a Senior Software Engineer and Performance Testing Analyst at Accenture with over 5 years of experience in performance testing, functional testing, and security testing. He has extensive experience using tools like LoadRunner, QC, and diagnostics tools to perform load, stress, endurance, and other types of performance tests on applications in the retail, utilities, and other domains. Rahul has worked on projects for clients such as Tesco, Best Buy, ALDO, and Hydro Quebec. He is proficient in languages like C and has strong analytical skills for performance testing and bottleneck analysis.
Software testing
Developers Belief on Software Testing
Developers Responsibility for testing
Test writing methods
State based testing
Behavioural/interaction based testing
Writing a Testable Code
Flaw 1 - Constructor does Real Work
Flaw 2 - API lies about it's real dependencies
Flaw 3 - Brittle Global State & Singletons
Testing Frameworks and tools for Java...
Mockito and PowerMock...
Testing Models
Stubs Based Testing Model
Mocked Objects Based Testing Model
JUit 4.+ and TestNG
https://www.adroitlogic.com
https://developer.adroitlogic.com
Test-Driven Development is about approaching software development from a test perspective and knowing how to use the tools (e.g. JUnit, Mockito) to effectively write tests.
Source code examples @...
https://github.com/codeprimate-software/test-driven-development
The document discusses continuous delivery and releasing software frequently through automation. It emphasizes building quality into the software process from the start using techniques like automated testing, configuration management, and continuous integration. This allows teams to reliably release new versions of software whenever required through the use of a deployment pipeline that automates testing, deployment and monitoring. Frequent releases help reduce risks and gather feedback to build the right product.
Test automation - Building effective solutionsArtem Nagornyi
This presentation is answering the questions: how to build an effective test automation framework, select the right tools and organize to whole process?
Agile testing - Principles and best practicesDr Ganesh Iyer
The document provides an overview of agile testing principles and best practices presented by three QA engineers from Progress Software in Hyderabad, India. It discusses how application development has evolved from command-line/GUI to cloud and mobile. It identifies seven key factors for agile testing success: having a whole team approach, automation, agile practices, a mindset change towards testing, providing timely feedback, collaborating with customers, and maintaining a big picture view. It also discusses challenges with agile methodology like frequently changing requirements and frequent releases. It promotes practices like continuous integration, automation, same sprint automation, GoLive testing automation, 24x7 testing, and emphasizing automation in agile testing.
7 Deadly Sins of Agile Software Test AutomationAdrian Smith
The document outlines 7 deadly sins of automated testing: envy, gluttony, lust, pride, sloth, rage, and greed. It discusses flaws in comparing manual and automated testing, overreliance on commercial tools, focus on user interfaces over architecture, lack of collaboration, poor maintenance, frustration with brittle tests, and attempts to cut costs rather than improve quality. The document advocates for collaboration, technical best practices, and treating tests as critical code.
Good practices for debugging Selenium and Appium testsAbhijeet Vaikar
We often come across situations when:
> We cannot figure out why our Selenium/Appium scripts fail during execution either locally or on CI.
> We need to debug scripts locally while writing them but find debugging painful and slow
Debugging the scripts is often the approach to fix them. What all different ways we can do it?
I shared about some of the good practices I have used for debugging Selenium and Appium scripts
Using Acceptance Test Driven Approach to Security Test, easy for stakeholder involvement, and a whole team approach to address security needs in software development process.
Examples in this session are based on RobotFramework, making it easy for people with limited programming skills.
This document provides an overview of test driven development (TDD). It discusses unit testing, refactoring, and the TDD process. The TDD process involves writing a failing test first, then code to pass the test, and refactoring code as needed. Adopting TDD practices can improve code quality and catch defects earlier. Examples are provided to illustrate applying TDD to a login feature.
Iasi code camp 20 april 2013 implement-quality-java-massol-codecampCodecamp Romania
This document discusses implementing quality practices on Java projects. It provides tips on API stability, such as using deprecations, CLIRR to track API changes, excluding internal packages from javadocs, and using annotations to mark unstable APIs. It also discusses preventing JAR hell by avoiding duplicate classes at runtime and ensuring correct dependency versions. The document recommends using Jacoco to enforce test coverage thresholds and failing the build when not met. It suggests strategies for improving functional test stability, such as ignoring known failure cases. Finally, it proposes designating regular bug fixing days to focus on resolving existing issues.
http://www.techforum.prathidhwani.org/appium/index.html
Appium Basics
Appium Desktop
Android Locator Types and Inspector Tools
Appium Capabilities
Mobile Interactions - Swipe and Scroll
Page Object Model and Dependency Injection
Real Device v/s Emulators / Simulators
iOS Automation
Cloud Automation
Appium Tips and Tricks
Please follow the steps in the below link to configure your system for the workshop
https://medium.com/@syamsasi/setting-up-appium-on-windows-and-ubuntu-ea9a73ab989
Webinar: Estrategias para optimizar los costos de testingFederico Toledo
This document discusses strategies for optimizing testing costs. It recommends involving testing earlier in the development process (shift left testing). It also suggests focusing testing on high risk areas and prioritizing based on probability and impact of failures (risk-based testing). The document outlines ways to optimize infrastructure/tooling costs such as migrating to open source tools, adopting new tools, and reviewing subscriptions and usage. It also provides tips for optimizing training costs like encouraging knowledge sharing and using online resources. Additionally, it advises optimizing processes by identifying waste, using lean principles, and considering different engagement models.
Have you ever wondered what the best way would be to test emails? Or how you would go about testing a messaging queue?
Making sure your components are correctly interacting with each other is both a tester and developer’s concern. Join us to get a better understanding of what you should test and how, both manually and automated.
This session is the first ever in which we will have two units working together to give you a nuanced insight on all aspects of integration testing. We’ll start off exploring the world of integration testing, defining the terminology, and creating a general understanding of what phases and kinds of testing exist. Later on we’ll delve into integration test automation, ranging from database integration testing to selenium UI testing and even as far as LDAP integration testing.
We have a wide variety of demos prepared where we will show you how easy it is to test various components of your infrastructure. Some examples:
- Database testing (JPA)
- Arquillian, exploring container testing, EJB testing and more
- Email testing
- SOAP testing using SoapUI
- LDAP testing
- JMS testing
Mastering NIST CSF 2.0 - The New Govern Function.pdfBachir Benyammi
Mastering NIST CSF 2.0 - The New Govern Function
Join us for an insightful webinar on mastering the latest updates to the NIST Cybersecurity Framework (CSF) 2.0, with a special focus on the newly introduced "Govern" function delivered by one of our founding members, Bachir Benyammi, Managing Director at Cyber Practice.
This session will cover key components such as leadership and accountability, policy development, strategic alignment, and continuous monitoring and improvement.
Don't miss this opportunity to enhance your organization's cybersecurity posture and stay ahead of emerging threats.
Secure your spot today and take the first step towards a more resilient cybersecurity strategy!
Event hosted by Sofiane Chafai, ISC2 El Djazair Chapter President
Watch the webinar on our YouTube channel: https://youtu.be/ty0giFH6Qp0
Testing doesn't have to be scary! Testing Paralysis is real! Join us for a deep dive into TestBox, the powerful BDD/TDD testing framework. Learn how to write clean, fluent tests, automate your workflows, and banish bugs with confidence. Whether you're new to testing or a seasoned pro, this session will equip you with the tools to kill off that paralysis and win!
SAP Automation with UiPath: SAP Test Automation - Part 5 of 8DianaGray10
This interesting webinar will show how UiPath can change how SAP Test Automation works. It will also show the main benefits and best ways to use UiPath with SAP.
Topics to be covered:
Learn about SAP test automation and why it's important for testing.
UiPath Overview: Learn how UiPath can make your SAP testing easier and faster.
Test Manager: Learn about the key advantages of automating your SAP tests, including increased accuracy and reduced time.
Best Practices: Get practical tips on how to use and improve test automation with UiPath.
Real-World Examples: Demonstration on how organizations have successfully leveraged UiPath for SAP test automation.
The Future is Here – Learn How to Get Started! Ionic App Development7Pillars
What is Ionic App Development? – A powerful framework for building high-performance, cross-platform mobile apps with a single codebase.
Key Benefits of Ionic App Development – Cost-effective, fast development, rich UI components, and seamless integration with native features.
Ionic App Development Process – Includes planning, UI/UX design, coding, testing, and deployment for scalable mobile solutions.
Why Choose Ionic for Your Mobile App? – Ionic offers flexibility, native-like performance, and strong community support for modern app development.
Future of Ionic App Development – Continuous updates, strong ecosystem, and growing adoption make Ionic a top choice for hybrid app development.
The Future of Materials: Transitioning from Silicon to Alternative Metalsanupriti
This presentation delves into the emerging technologies poised to revolutionize the world of computing. From carbon nanotubes and graphene to quantum computing and DNA-based systems, discover the next-generation materials and innovations that could replace or complement traditional silicon chips. Explore the future of computing and the breakthroughs that are shaping a more efficient, faster, and sustainable technological landscape.
Java on AWS Without the Headaches - Fast Builds, Cheap Deploys, No KubernetesVictorSzoltysek
Java Apps on AWS Without the Headaches: Fast Builds, Cheap Deploys, No Kubernetes
Let’s face it: the cloud has gotten out of hand. What used to be simple—deploying your Java app—has become a maze of slow builds, tedious deploys, and eye-watering AWS bills. But here’s the thing: it doesn’t have to be this way. Every minute you spend waiting on builds or wrestling with unnecessary cloud complexity is a minute you’re not building the features your customers actually care about.
In this talk, I’ll show you how to go from a shiny new Java app to production in under 10 minutes—with fast builds, cheap deploys, and zero downtime. We’ll go deep into optimizing builds with Gradle (it’s time to leave Maven in the dust), parallelization strategies, and smarter caching mechanics that make your CI/CD pipelines fly. From there, we’ll review the dozen+ ways AWS lets you deploy apps and cut through the chaos to find the solutions that work best for lean, fast, cost-effective pipelines. Spoiler: ECS and EKS usually aren’t the answer. Oh, and I’ll even show you how AI tools like AWS Bedrock can help streamline your processes further, so you can automate what should already be automatic.
This talk is for developers fed up with the cost, complexity, and friction of modern cloud setups—or those who long for the simplicity of the Heroku/Beanstalk/PCF days when deploying to the cloud wasn’t a headache. Whether you’re on AWS, Azure, or GCP, you’ll learn actionable, cloud-agnostic tips to build faster, deploy cheaper, and refocus on what matters most: delivering value to your users.
Building High-Impact Teams Beyond the Product Triad.pdfRafael Burity
The product triad is broken.
Not because of flawed frameworks, but because it rarely works as it should in practice.
When it becomes a battle of roles, it collapses.
It only works with clarity, maturity, and shared responsibility.
SAP Business Data Cloud: Was die neue SAP-Lösung für Unternehmen und ihre Dat...IBsolution GmbH
Inhalt:
Daten spielen für jede Business-Transformation eine entscheidende Rolle. Mithilfe der SAP Business Data Cloud (BDC) sind Unternehmen in der Lage, sämtliche Daten miteinander zu verbinden und zu harmonisieren. Die SAP BDC stellt eine Weiterentwicklung der bisherigen SAP-Datenstrategie dar - mit SAP Datasphere und der SAP Analytics Cloud (SAC) als elementaren Säulen. Besonders hervorzuheben: Databricks ist als OEM-Produkt in die Architektur integriert. Die SAP BDC kombiniert neue und bestehende Technologien, um Anwendern angereicherte Datenprodukte, fortschrittliche Analyse-Funktionalitäten und KI-gestützte Insights-Anwendungen bereitzustellen. Kurz gesagt: Mit SAP BDC schaffen Unternehmen eine zentrale Drehscheibe für ihre geschäftskritischen Daten und legen die Basis für SAP Business AI.
In unserem Expertengespräch erläutern Stefan Hoffmann (Head of Cross Solution Management SAP HANA & Analytics bei SAP) und Martin Eissing (Projektmanager bei IBsolution), was es mit der SAP Business Data Cloud genau auf sich hat und welche konkreten Vorteile mit dem neuen Angebot einhergehen. Außerdem zeigen sie auf, wie das erste Feedback der Kunden zur SAP BDC ausfällt und welche Wege Unternehmen zur SAP BDC führen.
Zielgruppe:
- IT-Leiter/IT-Entscheider
- Data Analysts
- Datenarchitekten
- BI-Spezialisten
- Anwender in den Fachbereichen
Agenda:
1. Was ist die SAP Business Data Cloud (BDC)?
2. Einordnung in die SAP-Datenstrategie
3. Voraussetzungen und Mehrwerte der SAP BDC
4. Architektur der SAP BDC
5. Handlungsempfehlungen für SAP BW-Kunden und SAP Datasphere-Kunden
6. Q&A
How AWS Encryption Key Options Impact Your Security and ComplianceChris Bingham
A rigorous approach to data encryption is increasingly essential for the security and compliance of all organizations, particularly here in Europe. However, all to often key management is neglected, and encryption itself ain’t worth much if your encryption keys are poorly managed!
AWS KMS offers a range of encryption key management approaches, each with very different impacts on both your overall information security and crucially which laws and regulations they enable compliance with.
Join this mini-webinar to learn about the choices you need to make, including:
• Your options for one of the most important decisions you can make for your AWS security posture.
• How your AWS KMS configuration choices can fundamentally alter your organization's regulatory compliance.
• Which AWS KMS option is right for your organization.
Safer’s Picks: The 6 FME Transformers You Didn’t Know You NeededSafe Software
With over 500 transformers in FME, it’s easy to stick to your favourites – but what about the hidden gems that could help you achieve more than you thought possible in your workspaces?
In this lightning talk-style webinar, our Safe team panel of FME Experts will highlight underutilized transformers and clever techniques that can make your workflows more powerful, efficient, and dynamic. Whether it’s a transformer you’ve never explored before or an unexpected way to use an old favourite, you’re sure to walk away with new ideas to enhance your FME skills.
Transformers they’ll cover include:
Donal, the MapnikRasterizer: Learn how to generate high-quality raster outputs from vector data with precise control over symbolization and labelling
Crystal, the SchemaScanner: Detect schema drift on the fly and dynamically set your output schema based on incoming data.
Mark, the ModuloCounter: Discover how to group features efficiently using the number of groups, rather than group size.
Evie, the Aggregator: See how versatile it can be for concatenating, listing, and joining data as an alternative to other transformers.
Natalie, the RasterExpressionEvaluator: Simplify raster expressions using presets to make them repeatable and easy to manage.
Dave, the ChangeDetector: Fine-tune output configurations to pinpoint exactly what’s changed in your data.
Join us for this fast-paced, insight-packed session and uncover the FME transformers you didn’t know you needed!
techfuturism.com-Autonomous Underwater Vehicles Navigating the Future of Ocea...Usman siddiqui
Imagine a robot diving deep into the ocean, exploring uncharted territories without human intervention. This is the essence of an autonomous underwater vehicle (AUV). These self-operating machines are revolutionizing our understanding of the underwater world, offering insights that were once beyond our reach.
An autonomous underwater vehicle is a type of unmanned underwater vehicle (UUV) designed to operate beneath the water’s surface without direct human control. Unlike remotely operated vehicles (ROVs), which are tethered to a ship and controlled by operators, AUVs navigate the ocean based on pre-programmed instructions or real-time adaptive algorithms.
Let's Create a GitHub Copilot Extension! - Nick Taylor, PomeriumAll Things Open
Presented at All Things Open AI 2025
Presented by Nick Taylor - Pomerium
Title: Let's Create a GitHub Copilot Extension!
Abstract: Get hands-on in this talk where we'll create a GitHub Copilot Extension from scratch.
We'll use the Copilot Extensions SDK, https://github.com/copilot-extensions/preview-sdk.js, and Hono.js, covering best practices like payload validation and progress notifications and error handling.
We'll also go through how to set up a dev environment for debugging, including port forwarding to expose your extension during development as well as the Node.js debugger.
By the end, we'll have a working Copilot extension that the audience can try out live.
Find more info about All Things Open:
On the web: https://www.allthingsopen.org/
Twitter: https://twitter.com/AllThingsOpen
LinkedIn: https://www.linkedin.com/company/all-things-open/
Instagram: https://www.instagram.com/allthingsopen/
Facebook: https://www.facebook.com/AllThingsOpen
Mastodon: https://mastodon.social/@allthingsopen
Threads: https://www.threads.net/@allthingsopen
Bluesky: https://bsky.app/profile/allthingsopen.bsky.social
2025 conference: https://2025.allthingsopen.org/
When Platform Engineers meet SREs - The Birth of O11y-as-a-Service SuperpowersEric D. Schabell
Monitoring the behavior of a system is essential to ensuring its long-term effectiveness. However, managing an end-to-end observability stack can feel like stepping into quicksand, without a clear plan you’re risking sinking deeper into system complexities.
In this talk, we’ll explore how combining two worlds—developer platforms and observability—can help tackle the feeling of being off the beaten cloud native path. We’ll discuss how to build paved paths, ensuring that adopting new developer tooling feels as seamless as possible. Further, we’ll show how to avoid getting lost in the sea of telemetry data generated by our systems. Implementing the right strategies and centralizing data on a platform ensures both developers and SREs stay on top of things. Practical examples are used to map out creating your very own Internal Developer Platform (IDP) with observability integrated from day 1.
This is session #5 of the 5-session online study series with Google Cloud, where we take you onto the journey learning generative AI. You’ll explore the dynamic landscape of Generative AI, gaining both theoretical insights and practical know-how of Google Cloud GenAI tools such as Gemini, Vertex AI, AI agents and Imagen 3.
2. what to expect
• Creating high quality acceptance tests
• How to structure a maintainable acceptance test
suite
• Patterns for effective teamwork
• Managing test data
Thursday, August 16, 12
3. what to take away
• Quality is everybody’s responsibility
• High quality test suites are continuously curated
- by testers and developers working together
• Test code needs to receive the same care as
production code
• Exhaustive story-level testing is not a good
basis for maintainable acceptance suites
Thursday, August 16, 12
4. different kinds of tests
Business facing
AUTOMATED MANUAL
Showcases
Support programming
Functional acceptance
Usability testing
tests
Critique project
Exploratory testing
Unit tests Non-functional
Integration tests acceptance tests
System tests (performance, scaling, ...)
AUTOMATED MANUAL / AUTOMATED
Technology facing
Diagram invented by Brian Marick
Thursday, August 16, 12
5. UI
Mike Cohn:
Succeeding with Agile
Service
Unit
Thursday, August 16, 12
6. End to End
Business Facing
Localized
Technology Facing
Thursday, August 16, 12
7. principle 0
Writing good acceptance tests is
hard.
(good: when the tests are green,
we know the software works)
Thursday, August 16, 12
8. mingle
2006 2012
20 tests 3000 tests
500 LOC 50k LOC
2 minutes 12 hours
• actual running time: 55 minutes
• 7-10 times a day
• for 6 years, across 4 offices now
Thursday, August 16, 12
9. why do test suites decay?
for the same reasons code does
we don’t pay enough attention to expressing intent
only testers care about maintaining tests
Thursday, August 16, 12
11. principle 1
Tests are first-class citizens of
your project
Thursday, August 16, 12
12. preventing decay in test code
treat test code as production c0de
refactor relentlessly
don’t repeat yourself
don’t repeat yourself
use record-playback tools to build your suite
Thursday, August 16, 12
13. preventing decay of intention
given-when-then is insufficient
separate intention from mechanics
express the test as steps of a user's journey
Thursday, August 16, 12
14. a solution
use natural language to express intentions
use a general purpose programming language to
express test mechanics
use a tool that allows you to operate in either
domain transparently
Thursday, August 16, 12
16. page object
https://gist.github.com/3345556
public class LoginPage {
private final SeleniumSession browser;
public LoginPage(Selenium browser){
this.browser = browser;
}
public HomePage loginAs(String user, String password){
browser.type('#login', login);
browser.type('#password', password);
browser.submit('#login-form');
return new HomePage(this.browser);
}
public HomePage loginExpectingError(String user, String password){
browser.type('#login', login);
browser.type('#password', password);
browser.submit('#login-form');
return new LoginPage(this.browser);
}
}
Thursday, August 16, 12
17. Acceptance Criteria
Customer Tester
Test implementation
Developer Tester
Thursday, August 16, 12
18. tester / quality analyst
...is a role, not a person
...is not a failed developer
...advocates for the user and makes the quality of the
system transparent
...should not be primarily working on manual
regression testing
...should be focussed on exploratory testing &
maintaining automated acceptance tests
Thursday, August 16, 12
19. remember
passing acceptance tests are necessary (but
insufficient) for “done”
encapsulate!
the acceptance tests are owned by - and the
responsibility of - the team
Thursday, August 16, 12
20. principle 2
always interact with the system
under test the same way a user
would
Thursday, August 16, 12
21. browser based tests are unreliable
"the test fails in CI, but when I run the app,
everything seems fine"
usually an indication that test mechanics and user
interaction patterns differ
ajax based tests?
JS heavy applications, which need non-zero
processing time to modify the UI
Thursday, August 16, 12
22. some solutions
Test your application the way a user might use it.
Understand when behavior is asynchronous and
account for it explicitly
Don’t use bare sleeps: poll
If it’s hard to write the test, you need to have a
conversation with the team
Thursday, August 16, 12
23. some solutions
wait-utils (https://github.com/itspanzi/WaitUtils)
for ajax tests, if your JS framework provides a pre-
and post-call hook, intercept those to count the
number of active calls before proceeding
Thursday, August 16, 12
25. remember
make time to go back and refactor your
tests
use layers and encapsulation: separate high
level intent and low level mechanics
use page object to interact with SUT; run
against service layer where possible
Thursday, August 16, 12
26. principle 3
continuously curate the structure
of your test suites
Thursday, August 16, 12
27. #1312
#1301 As a... I want... So that...
As a... I want... So that... #1310
As a... I want... So that... Given... Given...
Given... Given... #1306 When... When...
When... When... As a... I want... So that... Then... Then...
Given... Given...
Then... Then... When... #1304
When...
#1315 Given... Given... AsThen...
a... I want... So that...
Then...
When... When...
As a... I want... So that...
Then... Then... Given... Given...
Given... Given... #1308 When... When...
When... When... As a... I want... So that...
Then... Then...
#1307 Then... Then... #1313
As a... I want... So that... Given... Given... As a... I want... So that...
#1317 When... When...
Then...#1311
As a... I want... Then...
So that...
Given... Given... #1303 Given... Given...
When... When... As a... Given... So that... As a... I want... So When...
that... When...
I want... Given...
Then... Then... When... When... Then... Then...
Given... Given...
Given...
Then... Given...
Then... When... When...
When... When...
Then... Then...
Then... Then...
#1305
#1309 As a... I want... So that... #1302
As a... I want... So that... As a... I want... So that...
#1318
Given... Given... I want... So that...
Given... #1316
Given... When...
As a...
When... Given... #1314Given...
When... As a... I want... So that...
When... When... As a... I want... So that...
When...
Then... Then...
Given... Given... Then...
Then... Then... Then...
Given... Given... When... When... Given... Given...
When... When... Then... Then... When... When...
Then... Then... Then... Then...
Thursday, August 16, 12
28. journey tests
#1612
As a customer
I want a gift wrapping option
So that I don’t have to wrap
Buy Product them and post them myself Buy Product
Search product catalogue Search product catalogue
Add product to cart Add product to cart
Check out Check out
Create new account Create new account
Provide address details Provide address details
Provide credit card details Provide credit card details
Complete order Select gift wrapping option
Verify order created Complete order
Verify credit card debited Verify order created
Verify email sent Verify gift wrapping option
Verify credit card debited
Verify email sent
Thursday, August 16, 12
29. some solutions
identify user journeys
( journey: the path a persona takes through the
application to achieve an end goal)
most applications have very few distinct personas
most stories in iterative development are
enhancements to existing journeys
Thursday, August 16, 12
30. features
Basic shopping cart functionality
Searching for a product
- searching for a word should bring up all products which have that word in their name
- searching for a phrase should bring up all products which have any of the words in their
name
- searching for a quoted phrase should bring up all products which have all words in the
the quoted phrase in their name
Paginating search results
- return 25 results per page by default
- if there are fewer than 25 results, do not show pagination links
- provide a "previous" link on every page other than the first page of results
- provide a "next" link on every page other than the last page of results
- if user supplies a page number which is less than 1 in the URL, stay on the first page
- if the user supplies a page number greater than the last page of results, stay on the
last page
Gift-wrap option
Thursday, August 16, 12
31. story tests
Story tests for search
- test that searching for "friends" brings back 782 results
-- results should include how to win friends and influence people
- test that searching for dead friends brings back 8900 results
-- results should include <how to win friends and influence people>
-- results should include <The Zombie Survival Guide: Complete Protection from the
Living Dead>
- test that searching for "dead friends" brings back 57 results
-- results should include <all my friends are dead>
Story tests for pagination
- with a catalog of 3 products, I should see no pagination links
- with a catalog of 25 products, I should see no pagination links
- with a catalog of 26 products, I should see 1 link to page two, along with a next link
but no previous link
- with a catalog of 26 products, on page 2, I should see one product, with a link to
page one, a previous link but no next link
Story tests for gift wrapping
Thursday, August 16, 12
32. journey tests
Journey of user buying a book
- Login as user "bob"
- Search for <"my friends" dead>
- Make sure that 3 pages of results show
- Verify that "All My Friends Are Dead" by "Avery Monson" is on
the first page
- Add two copies of the book to the shopping cart
- Gift wrap one of them
- Proceed to checkout
Thursday, August 16, 12
33. more solutions
extract journeys from your acceptance tests
make them fast and run them first
do test the most likely path that the team, business
and UX folk agree upon
do not test every possible path through the system
extract negative tests and edge cases into a
regression suite which runs after your journey tests
Thursday, August 16, 12
34. build quality in
“Cease dependence on
mass inspection to achieve
quality. Improve the
process and build quality
into the product in the first
place”
W. Edwards Deming
Thursday, August 16, 12
35. why cross-functional teams?
output of testing is not just bug reports
feedback from testing to product design
feedback from test framework to system architecture
developers and testers share knowledge and skills
Thursday, August 16, 12
37. when acceptance tests break
Triage to find root cause
1. There was an environmental problem
2. There is a bug with the test
3. An assumption changed
4. The test actually caught a bug
Fix the problem
Add a guard to prevent it happening again
Optimise your test suite: detect failures fast
Optimise your process for time to fix tests
Thursday, August 16, 12
38. intermittent failures
flaky tests are worse than useless
quarantine flaky tests - but not forever
http://martinfowler.com/articles/
nonDeterminism.html
Thursday, August 16, 12
39. external systems
not all tests should call the external system
parameterize connections to external systems
Run integration smoke tests before full
acceptance suite
Thursday, August 16, 12
40. impersonator pattern
create a proxy from SUT to external system
cache results from integration smoke tests
run integration smoke tests before acceptance suite
periodically expire cache
only run acceptance suite if integration smoke tests
pass!
Thursday, August 16, 12
41. principle 5
acceptance tests are responsible
for managing their own test data
Thursday, August 16, 12
42. test data
Test-specific data
Test reference data
Application reference data
Ensure tests are independent
Don’t use production data dumps (except for
performance testing and staging)
Thursday, August 16, 12
43. recap
1. treat acceptance tests like production code
2. always interact with the SUT like a user would
3. continuously curate your user journeys
4. collective ownership of acceptance tests
5. acceptance tests own their data
Thursday, August 16, 12
44. take-aways
• quality is everybody’s responsibility
• high quality test suites are continuously curated
- by testers and developers working together
• test code needs to receive the same care as
production code
• exhaustive story-level testing is not a good
basis for maintainable acceptance suites
Thursday, August 16, 12