SlideShare a Scribd company logo
@jphenow
What TDD Can Teach
Us About API Design
Jon Phenow
Highrise
@jphenow
What is TDD?
@jphenow
Test Driven Development
• Test first
• Run and watch test fail
• Fill in the funcGonality that makes the test pass
• Run and watch test pass
@jphenow
TDD Benefits
• Proof
• Fast feedback loop
• Test Coverage
• Code Design
@jphenow
TDD’s Effect on Design
• Testable code is usable code
• Explicitly illustrates dependencies of an operaGon
• Exposes difficulty
@jphenow
• Design is affected because of perspecGve
• WriGng as a user
• Not wriGng what’s simple as an author
TDD’s Effect on PerspecGve
@jphenow
PerspecGve is everything
@jphenow
API Design is like UX Design
@jphenow
What’s an API User
• Not user bob vs. user alice
• Topical
@jphenow
An API workflow
• Get a Client Token
• AuthenGcate to receive a user token
• Make requests using this token
@jphenow
Let’s Talk Real World
@jphenow
“Real” World
• Legacy CMS for Tiered Sports OrganizaGons
• Leagues, divisions, teams, games
• Third-Party wants to automaGcally update game
statuses due to weather informaGon from their
system
@jphenow
“Real” World
• Call support for an API Key
• Copy this key into headers
• Query CMS nodes for leagues matching our query
• Query each of those for children nodes that are teams
• Query each of those for a list of games that would be
affected by today’s weather
• Update each of those because its too nice out to play
baseball today
@jphenow
This sucks
@jphenow
First-glance Problems
• Client admin
• Lots of steps to get something done
• Design of the legacy internals is bleeding out
@jphenow
Dealing with bleeding out
@jphenow
Bleeding out
• Consider who’s using your API
• A Sport CMS with an API probably has disGnct two
users
• Sports/Stats
• Content/Site Structure
@jphenow
@jphenow
Fix it
• Separate Users
• Your internal choices shouldn’t necessarily bleed out
• DisGll funcGonality and data
@jphenow
Recall Some “Real” World
• Query CMS nodes for leagues matching our query
• Query each of those for children nodes that are
teams
• Query each of those for a list of games that would
be affected by today’s weather
• Update each of those because its too nice out to
play baseball today
@jphenow
Fix it
• Don’t solve for cancelling all rained-out games at
once
• Solve for updaGng a group of games with search
parameters
@jphenow
Don’t over fix it
• Only a few types of users
• Focus on the 80%
@jphenow
There are limits
• Be protecGve of what you provide
• Performance
@jphenow
Low-FricGon APIs Are
a Feature
@jphenow
PerspecGve is the key
@jphenow
Things I didn’t address
• Protocol/Pafern: SOAP/REST
• AuthenGcaGon: SAML/OAuth2/JWT
• API Versioning
@jphenow
Conclusion
• API Design is hard
• To the user it should feel fun, simple and powerful
• Consider what you have, what they want and
express that in an API
@jphenow
@jphenow
Ad

Recommended

Unstoppable releases with kanban
Unstoppable releases with kanban
Andrii Shumada
 
Agile Project Management: "How I Learned to Stop Worrying and Love Agile”
Agile Project Management: "How I Learned to Stop Worrying and Love Agile”
VersionOne
 
Agile Testing
Agile Testing
VersionOne
 
Right-Sizing User Stories
Right-Sizing User Stories
VersionOne
 
Selenium Shots by Kyle J. Ginavan & Ryan Felton
Selenium Shots by Kyle J. Ginavan & Ryan Felton
Steven Chau
 
Tdd2018 state of the software quality in Germany
Tdd2018 state of the software quality in Germany
Orlovsky Consulting GbR
 
Job manager 2020 in Angular
Job manager 2020 in Angular
Orlovsky Consulting GbR
 
Boquet manager
Boquet manager
Orlovsky Consulting GbR
 
Developer Night Opticon 2017
Developer Night Opticon 2017
Optimizely
 
Drulenium - Testing Made Easy
Drulenium - Testing Made Easy
nyccamp
 
Becoming a better programmer - unit testing
Becoming a better programmer - unit testing
Duy Tan Geek
 
JavaScript Unit Testing
JavaScript Unit Testing
Keir Bowden
 
Peer review
Peer review
Charuta Joshi
 
Productive teams
Productive teams
Amir Barylko
 
Responsive App Design with the Salesforce Lightning Design System
Responsive App Design with the Salesforce Lightning Design System
Keir Bowden
 
Automated Performance Testing
Automated Performance Testing
Lars Thorup
 
Developer Testing
Developer Testing
Chris Wallace
 
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
GeeksLab Odessa
 
Don't lose revenue. Go viral with no downtime.
Don't lose revenue. Go viral with no downtime.
WP Engine
 
Fast end-to-end-tests
Fast end-to-end-tests
Rikke Veng Petersen
 
Developer Night - Opticon18
Developer Night - Opticon18
Optimizely
 
Using real customer data to drive Testing
Using real customer data to drive Testing
Eggplant
 
Unit testing for project managers
Unit testing for project managers
Zend by Rogue Wave Software
 
Spot the difference - automating visual regression testing
Spot the difference - automating visual regression testing
Viv Richards
 
15 Explosive Things You Should Try As An Agilist by Peter Gfader
15 Explosive Things You Should Try As An Agilist by Peter Gfader
Bosnia Agile
 
TLC2018 Shyam Sunder: Legoizing Testing
TLC2018 Shyam Sunder: Legoizing Testing
Anna Royzman
 
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely
 
Test Driven Development
Test Driven Development
Hicham El Hammouchi
 
Psv tahun 6
Psv tahun 6
gansforever
 
high temprature
high temprature
Sathees Physics
 

More Related Content

What's hot (20)

Developer Night Opticon 2017
Developer Night Opticon 2017
Optimizely
 
Drulenium - Testing Made Easy
Drulenium - Testing Made Easy
nyccamp
 
Becoming a better programmer - unit testing
Becoming a better programmer - unit testing
Duy Tan Geek
 
JavaScript Unit Testing
JavaScript Unit Testing
Keir Bowden
 
Peer review
Peer review
Charuta Joshi
 
Productive teams
Productive teams
Amir Barylko
 
Responsive App Design with the Salesforce Lightning Design System
Responsive App Design with the Salesforce Lightning Design System
Keir Bowden
 
Automated Performance Testing
Automated Performance Testing
Lars Thorup
 
Developer Testing
Developer Testing
Chris Wallace
 
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
GeeksLab Odessa
 
Don't lose revenue. Go viral with no downtime.
Don't lose revenue. Go viral with no downtime.
WP Engine
 
Fast end-to-end-tests
Fast end-to-end-tests
Rikke Veng Petersen
 
Developer Night - Opticon18
Developer Night - Opticon18
Optimizely
 
Using real customer data to drive Testing
Using real customer data to drive Testing
Eggplant
 
Unit testing for project managers
Unit testing for project managers
Zend by Rogue Wave Software
 
Spot the difference - automating visual regression testing
Spot the difference - automating visual regression testing
Viv Richards
 
15 Explosive Things You Should Try As An Agilist by Peter Gfader
15 Explosive Things You Should Try As An Agilist by Peter Gfader
Bosnia Agile
 
TLC2018 Shyam Sunder: Legoizing Testing
TLC2018 Shyam Sunder: Legoizing Testing
Anna Royzman
 
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely
 
Test Driven Development
Test Driven Development
Hicham El Hammouchi
 
Developer Night Opticon 2017
Developer Night Opticon 2017
Optimizely
 
Drulenium - Testing Made Easy
Drulenium - Testing Made Easy
nyccamp
 
Becoming a better programmer - unit testing
Becoming a better programmer - unit testing
Duy Tan Geek
 
JavaScript Unit Testing
JavaScript Unit Testing
Keir Bowden
 
Responsive App Design with the Salesforce Lightning Design System
Responsive App Design with the Salesforce Lightning Design System
Keir Bowden
 
Automated Performance Testing
Automated Performance Testing
Lars Thorup
 
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
WebCamp: Project Management Day: Управление требованиями в Agile: как это про...
GeeksLab Odessa
 
Don't lose revenue. Go viral with no downtime.
Don't lose revenue. Go viral with no downtime.
WP Engine
 
Developer Night - Opticon18
Developer Night - Opticon18
Optimizely
 
Using real customer data to drive Testing
Using real customer data to drive Testing
Eggplant
 
Spot the difference - automating visual regression testing
Spot the difference - automating visual regression testing
Viv Richards
 
15 Explosive Things You Should Try As An Agilist by Peter Gfader
15 Explosive Things You Should Try As An Agilist by Peter Gfader
Bosnia Agile
 
TLC2018 Shyam Sunder: Legoizing Testing
TLC2018 Shyam Sunder: Legoizing Testing
Anna Royzman
 
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely NYC Developer Meetup - Experimentation at Blue Apron
Optimizely
 

Viewers also liked (8)

Psv tahun 6
Psv tahun 6
gansforever
 
high temprature
high temprature
Sathees Physics
 
Mirando el sie 2
Mirando el sie 2
Diana Marcela Rincon Rodriguez
 
Transformada de laplace
Transformada de laplace
antonio guevara
 
Yeu to con_nguoi
Yeu to con_nguoi
Pham Van van Dinh
 
Properties and Changes
Properties and Changes
Jamie Ayers
 
Acids and Bases
Acids and Bases
Jamie Ayers
 
Over view about mba
Over view about mba
Pham Van van Dinh
 
Ad

Similar to What TDD Can Teach Us About API Design (20)

Performance tuning
Performance tuning
Eric Phan
 
Software testing and quality assurance
Software testing and quality assurance
Benjamin Baumann
 
That worked before
That worked before
Christian Güdemann
 
Magento 2 Performance: Every Second Counts
Magento 2 Performance: Every Second Counts
Joshua Warren
 
15 tips for bullet proof requirements analysis on SharePoint projects
15 tips for bullet proof requirements analysis on SharePoint projects
DocFluix, LLC
 
Why do mobile projects (still) fail - September 2014 edition
Why do mobile projects (still) fail - September 2014 edition
Indiginox
 
What a DevOps specialist has to know about static code analysis
What a DevOps specialist has to know about static code analysis
Andrey Karpov
 
Success of Blackfire and Continuos PHP performance monitoring at trivago
Success of Blackfire and Continuos PHP performance monitoring at trivago
Jorge Luis Betancourt Gonzalez
 
Socialcam: Concept to MVP to 250k users in under 3 Months
Socialcam: Concept to MVP to 250k users in under 3 Months
Lean Startup Circle
 
Code Palousa presentation- "Giving Digital Eyes to your Synthetic Tests"
Code Palousa presentation- "Giving Digital Eyes to your Synthetic Tests"
Christopher Hamm
 
Что нам стоіт таск манагер построіт. Ігор Лущик. LvivPy #6
Что нам стоіт таск манагер построіт. Ігор Лущик. LvivPy #6
Serhii Ruskykh
 
Untangling spring week11
Untangling spring week11
Derek Jacoby
 
Real-Time Metrics and Distributed Monitoring - Jeff Pierce, Change.org - Dev...
Real-Time Metrics and Distributed Monitoring - Jeff Pierce, Change.org - Dev...
DevOpsDays Tel Aviv
 
SPSVB 2013 Everything About SharePoint 2010 Workflows
SPSVB 2013 Everything About SharePoint 2010 Workflows
Prashant G Bhoyar (Microsoft MVP)
 
파이콘한국2017 - Years with Python
파이콘한국2017 - Years with Python
Younggun Kim
 
Opticon 2017 How Developers Can Take Experimentation
Opticon 2017 How Developers Can Take Experimentation
Optimizely
 
Full stack conference talk slides
Full stack conference talk slides
Sameer Al-Sakran
 
How to do b tech be projects or any academic projects
How to do b tech be projects or any academic projects
baabtra.com - No. 1 supplier of quality freshers
 
Data Driven DevOps
Data Driven DevOps
Leon Stigter
 
Fuel Good 2018: Upgrades Made Easy: The Canadian Museum of History
Fuel Good 2018: Upgrades Made Easy: The Canadian Museum of History
Sparkrock
 
Performance tuning
Performance tuning
Eric Phan
 
Software testing and quality assurance
Software testing and quality assurance
Benjamin Baumann
 
Magento 2 Performance: Every Second Counts
Magento 2 Performance: Every Second Counts
Joshua Warren
 
15 tips for bullet proof requirements analysis on SharePoint projects
15 tips for bullet proof requirements analysis on SharePoint projects
DocFluix, LLC
 
Why do mobile projects (still) fail - September 2014 edition
Why do mobile projects (still) fail - September 2014 edition
Indiginox
 
What a DevOps specialist has to know about static code analysis
What a DevOps specialist has to know about static code analysis
Andrey Karpov
 
Success of Blackfire and Continuos PHP performance monitoring at trivago
Success of Blackfire and Continuos PHP performance monitoring at trivago
Jorge Luis Betancourt Gonzalez
 
Socialcam: Concept to MVP to 250k users in under 3 Months
Socialcam: Concept to MVP to 250k users in under 3 Months
Lean Startup Circle
 
Code Palousa presentation- "Giving Digital Eyes to your Synthetic Tests"
Code Palousa presentation- "Giving Digital Eyes to your Synthetic Tests"
Christopher Hamm
 
Что нам стоіт таск манагер построіт. Ігор Лущик. LvivPy #6
Что нам стоіт таск манагер построіт. Ігор Лущик. LvivPy #6
Serhii Ruskykh
 
Untangling spring week11
Untangling spring week11
Derek Jacoby
 
Real-Time Metrics and Distributed Monitoring - Jeff Pierce, Change.org - Dev...
Real-Time Metrics and Distributed Monitoring - Jeff Pierce, Change.org - Dev...
DevOpsDays Tel Aviv
 
파이콘한국2017 - Years with Python
파이콘한국2017 - Years with Python
Younggun Kim
 
Opticon 2017 How Developers Can Take Experimentation
Opticon 2017 How Developers Can Take Experimentation
Optimizely
 
Full stack conference talk slides
Full stack conference talk slides
Sameer Al-Sakran
 
Data Driven DevOps
Data Driven DevOps
Leon Stigter
 
Fuel Good 2018: Upgrades Made Easy: The Canadian Museum of History
Fuel Good 2018: Upgrades Made Easy: The Canadian Museum of History
Sparkrock
 
Ad

Recently uploaded (20)

How Insurance Policy Management Software Streamlines Operations
How Insurance Policy Management Software Streamlines Operations
Insurance Tech Services
 
SAP PM Module Level-IV Training Complete.ppt
SAP PM Module Level-IV Training Complete.ppt
MuhammadShaheryar36
 
How the US Navy Approaches DevSecOps with Raise 2.0
How the US Navy Approaches DevSecOps with Raise 2.0
Anchore
 
Open Source Software Development Methods
Open Source Software Development Methods
VICTOR MAESTRE RAMIREZ
 
Step by step guide to install Flutter and Dart
Step by step guide to install Flutter and Dart
S Pranav (Deepu)
 
Women in Tech: Marketo Engage User Group - June 2025 - AJO with AWS
Women in Tech: Marketo Engage User Group - June 2025 - AJO with AWS
BradBedford3
 
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Philip Schwarz
 
Advanced Token Development - Decentralized Innovation
Advanced Token Development - Decentralized Innovation
arohisinghas720
 
Artificial Intelligence Workloads and Data Center Management
Artificial Intelligence Workloads and Data Center Management
SandeepKS52
 
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
IFI Techsolutions
 
Transmission Media. (Computer Networks)
Transmission Media. (Computer Networks)
S Pranav (Deepu)
 
On-Device AI: Is It Time to Go All-In, or Do We Still Need the Cloud?
On-Device AI: Is It Time to Go All-In, or Do We Still Need the Cloud?
Hassan Abid
 
Insurance Underwriting Software Enhancing Accuracy and Efficiency
Insurance Underwriting Software Enhancing Accuracy and Efficiency
Insurance Tech Services
 
What is data visualization and how data visualization tool can help.pdf
What is data visualization and how data visualization tool can help.pdf
Varsha Nayak
 
Decipher SEO Solutions for your startup needs.
Decipher SEO Solutions for your startup needs.
mathai2
 
wAIred_RabobankIgniteSession_12062025.pptx
wAIred_RabobankIgniteSession_12062025.pptx
SimonedeGijt
 
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Safe Software
 
Application Modernization with Choreo - The AI-Native Internal Developer Plat...
Application Modernization with Choreo - The AI-Native Internal Developer Plat...
WSO2
 
Wondershare PDFelement Pro 11.4.20.3548 Crack Free Download
Wondershare PDFelement Pro 11.4.20.3548 Crack Free Download
Puppy jhon
 
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
BradBedford3
 
How Insurance Policy Management Software Streamlines Operations
How Insurance Policy Management Software Streamlines Operations
Insurance Tech Services
 
SAP PM Module Level-IV Training Complete.ppt
SAP PM Module Level-IV Training Complete.ppt
MuhammadShaheryar36
 
How the US Navy Approaches DevSecOps with Raise 2.0
How the US Navy Approaches DevSecOps with Raise 2.0
Anchore
 
Open Source Software Development Methods
Open Source Software Development Methods
VICTOR MAESTRE RAMIREZ
 
Step by step guide to install Flutter and Dart
Step by step guide to install Flutter and Dart
S Pranav (Deepu)
 
Women in Tech: Marketo Engage User Group - June 2025 - AJO with AWS
Women in Tech: Marketo Engage User Group - June 2025 - AJO with AWS
BradBedford3
 
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Folding Cheat Sheet # 9 - List Unfolding 𝑢𝑛𝑓𝑜𝑙𝑑 as the Computational Dual of ...
Philip Schwarz
 
Advanced Token Development - Decentralized Innovation
Advanced Token Development - Decentralized Innovation
arohisinghas720
 
Artificial Intelligence Workloads and Data Center Management
Artificial Intelligence Workloads and Data Center Management
SandeepKS52
 
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
Enable Your Cloud Journey With Microsoft Trusted Partner | IFI Tech
IFI Techsolutions
 
Transmission Media. (Computer Networks)
Transmission Media. (Computer Networks)
S Pranav (Deepu)
 
On-Device AI: Is It Time to Go All-In, or Do We Still Need the Cloud?
On-Device AI: Is It Time to Go All-In, or Do We Still Need the Cloud?
Hassan Abid
 
Insurance Underwriting Software Enhancing Accuracy and Efficiency
Insurance Underwriting Software Enhancing Accuracy and Efficiency
Insurance Tech Services
 
What is data visualization and how data visualization tool can help.pdf
What is data visualization and how data visualization tool can help.pdf
Varsha Nayak
 
Decipher SEO Solutions for your startup needs.
Decipher SEO Solutions for your startup needs.
mathai2
 
wAIred_RabobankIgniteSession_12062025.pptx
wAIred_RabobankIgniteSession_12062025.pptx
SimonedeGijt
 
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Automated Migration of ESRI Geodatabases Using XML Control Files and FME
Safe Software
 
Application Modernization with Choreo - The AI-Native Internal Developer Plat...
Application Modernization with Choreo - The AI-Native Internal Developer Plat...
WSO2
 
Wondershare PDFelement Pro 11.4.20.3548 Crack Free Download
Wondershare PDFelement Pro 11.4.20.3548 Crack Free Download
Puppy jhon
 
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
Milwaukee Marketo User Group June 2025 - Optimize and Enhance Efficiency - Sm...
BradBedford3
 

What TDD Can Teach Us About API Design