SlideShare a Scribd company logo
Test Data Builder
Pattern
Alan Parkinson
CEO, Hindsight Software
@alan_parkinson
Tests
Application
Under Test
Application
Database
Mobile App Server
Drop and reload the
database before
every test
Who has done this?
Database
reloading is an
Anti Pattern
Creating and maintaining SQL
scripts is error prone and time
consuming
Tests
Application
Under Test
Application
Database
Limitations of CI Scaling
Tests
Application
Under Test
Application
Database
What if we could generate
test data on demand?
Create test data on-
demand
with the Test Data
Builder Pattern
What is a Builder?
new UserBuilder()
an object that knows how to construct another
object
User user = .build();
the object is complex to
construct
public class UserBuilder {
uses sensible default values
}
public User build() {
return new User(name, password,
email);
}
private String name = ``charlie``;
private String password = ``password``;
private String email = ``charlie@behave.pro``;
Overriding sensible
defaults
new UserBuilder()user = .build();
.withName(``alan
``).withPassword(``secr
et``)
Overriding sensible defaults
public class UserBuilder {
}
public User build() {
return new User(name, password, email);
}
private String name = ``charlie``;
private String password = ``password``;
private String email = ``charlie@behave.pro``;
public UserBuilder withName(String name) {
this.name = name;
return this;
}
What about the Test
Data?
create remote data
instead of an object
public class UserBuilder {
}
public UserDesc build() {
/*
Create data using SQL / REST API / UI?
*/
return new UserDesc(createdUserId);
}
private String name = ``charlie``;
private String password = ``password``;
private String email = ``charlie@behave.pro``;
public UserBuilder withName(String name) {
this.name = name;
return this;
}
Don`t drop and reload
the database
Generate and construct
Test Data on-demand
Abstract data contruction
complexity with the
Builder Pattern
Questions?
Alan Parkinson
CEO, Hindsight Software
@alan_parkinson

More Related Content

PDF
Alphorm.com Formation Analyse de Malware 2/2 : Le guide complet
PDF
DataASAP - Create Test Data Fast
PPTX
Creating data with the test data builder pattern
PPTX
هادوپ چيست؟
PDF
Hadoop Case Studies in the Real World in Persian - کاربردهای هدوپ در دنیای واقعی
PPTX
Sql Injection V.2
PPTX
Easy data-with-spring-data-jpa
PPTX
Alphorm.com Formation Analyse de Malware 2/2 : Le guide complet
DataASAP - Create Test Data Fast
Creating data with the test data builder pattern
هادوپ چيست؟
Hadoop Case Studies in the Real World in Persian - کاربردهای هدوپ در دنیای واقعی
Sql Injection V.2
Easy data-with-spring-data-jpa

Similar to Test Data Builder Pattern (20)

DOCX
Labs And Walkthroughs
PPTX
jdbcppt.pptx , jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt
PPTX
jdbcppt.pptx , jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt
PDF
New Features of JSR 317 (JPA 2.0)
PDF
Data Seeding via Parameterized API Requests
PPT
SQLSecurity.ppt
PPT
SQLSecurity.ppt
PPTX
Database connectivity in python
PPTX
Microsoft Entity Framework
PPTX
Sql injection
PPTX
Evaluating Test Driven Development And Parameterized Unit Testing In Dot Net ...
PDF
Easy integration of Bluemix services with your applications
PPTX
Building Your First App with MongoDB Stitch
PDF
apidays LIVE LONDON - Exploring an API with Blocks by Larry Kluger
PPTX
cosmodb ppt project.pptxakfjhaasjfsdajjkfasd
PPTX
WebAppseqweqweqweqwewqeqweqweReImagined.pptx
PPT
Integrating an App with Amazon Web Services SimpleDB - A Matter of Choices
PDF
Firebase on Android: The Big Picture
PPTX
Testing database content with DBUnit. My experience.
PPT
SQL Server 2008 Data Mining
Labs And Walkthroughs
jdbcppt.pptx , jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt
jdbcppt.pptx , jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt jdbc ppt
New Features of JSR 317 (JPA 2.0)
Data Seeding via Parameterized API Requests
SQLSecurity.ppt
SQLSecurity.ppt
Database connectivity in python
Microsoft Entity Framework
Sql injection
Evaluating Test Driven Development And Parameterized Unit Testing In Dot Net ...
Easy integration of Bluemix services with your applications
Building Your First App with MongoDB Stitch
apidays LIVE LONDON - Exploring an API with Blocks by Larry Kluger
cosmodb ppt project.pptxakfjhaasjfsdajjkfasd
WebAppseqweqweqweqwewqeqweqweReImagined.pptx
Integrating an App with Amazon Web Services SimpleDB - A Matter of Choices
Firebase on Android: The Big Picture
Testing database content with DBUnit. My experience.
SQL Server 2008 Data Mining
Ad

More from Alan Parkinson (13)

PPTX
Testing requirements with BDD
PPTX
Baking in the cloud with packer and puppet
PPTX
Decapitating Selenium with JavaScript
PPTX
Pull requests and testers can be friends
PPTX
What is Continuous Delivery?
PPTX
Cross browser Testing JavaScript
PPTX
Why we used Feature Branching
PPTX
Test automation with Cucumber-JVM
PPTX
A Quick overview of Behaviour Driven Development (BDD)
PPTX
Cross-browser unit testing JavaScript
PPTX
Acceptance test styles - Imperative vs Declarative
PPTX
Continuous Deployment Pipeline with maven
PPTX
Feature branching a release day painkiller
Testing requirements with BDD
Baking in the cloud with packer and puppet
Decapitating Selenium with JavaScript
Pull requests and testers can be friends
What is Continuous Delivery?
Cross browser Testing JavaScript
Why we used Feature Branching
Test automation with Cucumber-JVM
A Quick overview of Behaviour Driven Development (BDD)
Cross-browser unit testing JavaScript
Acceptance test styles - Imperative vs Declarative
Continuous Deployment Pipeline with maven
Feature branching a release day painkiller
Ad

Recently uploaded (20)

PDF
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
PDF
AI in Product Development-omnex systems
PPTX
Odoo POS Development Services by CandidRoot Solutions
PDF
wealthsignaloriginal-com-DS-text-... (1).pdf
PDF
Nekopoi APK 2025 free lastest update
PDF
Wondershare Filmora 15 Crack With Activation Key [2025
PPTX
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
PPTX
VVF-Customer-Presentation2025-Ver1.9.pptx
PDF
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
PDF
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
PDF
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
PDF
Odoo Companies in India – Driving Business Transformation.pdf
PPTX
history of c programming in notes for students .pptx
PDF
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
PPTX
Reimagine Home Health with the Power of Agentic AI​
PDF
How to Migrate SBCGlobal Email to Yahoo Easily
PDF
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
PDF
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
PPTX
Introduction to Artificial Intelligence
PPTX
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...
SAP S4 Hana Brochure 3 (PTS SYSTEMS AND SOLUTIONS)
AI in Product Development-omnex systems
Odoo POS Development Services by CandidRoot Solutions
wealthsignaloriginal-com-DS-text-... (1).pdf
Nekopoi APK 2025 free lastest update
Wondershare Filmora 15 Crack With Activation Key [2025
Lecture 3: Operating Systems Introduction to Computer Hardware Systems
VVF-Customer-Presentation2025-Ver1.9.pptx
EN-Survey-Report-SAP-LeanIX-EA-Insights-2025.pdf
Why TechBuilder is the Future of Pickup and Delivery App Development (1).pdf
Addressing The Cult of Project Management Tools-Why Disconnected Work is Hold...
Odoo Companies in India – Driving Business Transformation.pdf
history of c programming in notes for students .pptx
Adobe Premiere Pro 2025 (v24.5.0.057) Crack free
Reimagine Home Health with the Power of Agentic AI​
How to Migrate SBCGlobal Email to Yahoo Easily
Flood Susceptibility Mapping Using Image-Based 2D-CNN Deep Learnin. Overview ...
Audit Checklist Design Aligning with ISO, IATF, and Industry Standards — Omne...
Introduction to Artificial Intelligence
Agentic AI : A Practical Guide. Undersating, Implementing and Scaling Autono...

Test Data Builder Pattern