SlideShare a Scribd company logo
Patterns to scale mobile teams
Using examples for Android
Priyank Gupta
Sahaj Software Solutions Pvt. Ltd.
Mobile is eating the world
Evolution in last 5 years
Mobile Inclusive Mobile First Mobile Only
Building it for 3.2 billion people
7.1 Billion - World population
7.9 Billion mobile devices
3.2 Billion Internet Users
State of connectivity 2015 - Report
Mobile users are the internet users
Worldwide market-share
Smartphone market share - Report
Android
iOS
Others
83%
14%
03%
Everything in ‘context’
Discovery
DeliveryMedia
Payments
Aggregation
Discovering content, deals, products,
places and information happens
based on location, context and
conversations..
Payments, wallets, money transfers
and currency conversions happens
via mobile apps instantaneously.
News doesn’t come from media
houses. News is crowd sourced,
crowd curated and pushed real-time
to consumers on mobile.
Delivery is done across diverse
products and services; ordered,
scheduled and tracked via mobile
real-time.
Services are aggregated and made
available on mobile across all domains.
Delivery, taxis, food, handy-work etc.
Why mobile is different?
Challenges
Multiple
platforms and
form types
No control on
environment /
device
Work across
version and
device types
Design with
usability at
center. Stay
ahead of
competing
feature set
Forced SDK
update and
different
runtimes
Dalvik, ART,
Arm6, Arm7
Survival for fittest
Ideas
Tons of ideas see
daylight in an healthy
ecosystem
Saturation
Redundant businesses
cause saturation to occur
Consolidation
Consolidation in form of acquisition,
mergers and natural death.
Healthy co-existence
Winning teams are lean,
agile, ahead of competition
and know how to scale.
What affects scalability
Things that matter
Hiring & People
Team organization
Technology selection
Development practices
Scalable design
Testing & Safety nets
Release cycle & practices
Technology selection
In business of delivering experience
HTML5
Native
Custom
Bridges
Cordova
HTML5+
Service workers
React
Native
Xamarin
Selecting mobile implementation strategy
Experience + Reach
Cost
Laser
Cover your bases
Long term strategy should focus on building a native experience. The journey can
be gradual or with a jump start.
No adoption
No magic bullets
Organizing teams for scale
Technology teams vs..
Release 1 - Mix of feature X & Y
Android
iOS
Services
Siloed by
technology
/platform
If feature parity is
important then
lowest
denominator goes
into release
Missed opportunity
to optimize services
based on common
domain across
platform
Easier to draw
boundaries.
Initial velocity
gain due to
technical
know how.
.. Product team
Release 1 - Feature X
Release 1 - Feature Y
Services iOS Android
Initial
velocity
impact
Shared
understanding
of product as a
whole
Feature
parity
maintained in
releases
Can get away
with a leaner
team.
Problems
solved once.
Service design
can have
considerations
for clients
baked in right
from start
Handovers & feedback loops
Development
Design
Testing
Story started
Story done
Quicker feedback loops keeps the cost of change low
and validates the shared understanding constantly.
Services are part of product
Services
App
Own
services as
first class
deliverable
Use patterns
to decouple
legacy
services
Leverage REST
Level-3
characteristics to
make service
adaptive
Use patterns to
optimize services
for target
consumer
platform
Scaleable dev practices
Predictability & Consistency
Where would you find the code to fetch details from database?
Can you predict how someone on team would fetch images in background?
Will everyone know how to find the service call you wrote?
Can everyone on team predict what’s going to be covered in an espresso test?
Do you know where to find the styling for a specific UI element?
Using conventions you can build predictability on team to simplify mental models
needed to understand the codebase
Define the simple machines
Screw Wheel & Axle Pulley Lever
A simple machine can hammer in the basic principle and allow far
more complex machines to be developed with coherence.
Adopting patterns
Persistence /
db
Web ServicesUI / Styles Debugging
Invest time in first of everything. Build a team-wide definition and
reuse the pattern to promote consistency and predictability.
Background
tasks / Services
Device
hardware
Web service patterns
for consistent service calls across features.Retrofit + Singletons + Observers
Callback implementation
for Retrofit API (Singleton)
Retrofit service
interface
Observers
Activities,
fragments or
services
Data retrieved from
service (possibly cached)
External integrations patterns
BFF approach | Adaptive API
Adaptive API
Backend for
frontend
Downstream systems
Adaptive proxy APIs
Consumer centric
abstractions - BFFs
for optimal experience of services on devicesAdaptive APIs BFFsor
for consistent execution of short async tasksAsync task wrapper + Observers Thread (Pools)or
Asynchronous tasks patterns
Obtain instance
Set data
Fire task
Check references
Call observers
Die or loop
Main thread
Spawned/Pooled thread
Scaling commits with patterns
Feature one
Feature two
Master
Feature toggles explained
vs
Requires complex CI setup to constantly identify and
merge branches and test state at any point of time.
Requires building a feature toggle functionality with
dynamic toggles and tests to validate all feasible path.
Master
Feature one
toggled off
Feature two
toggled off
Feature two
toggled on
Feature one
toggled on
Debugging and logging patterns
Force upgrade Debug console Thread local
logging
Crashlytics
Build consistent set of practices to debug issues using Debug console Crashlytics Thread logging
Building reliable safety nets
TDD - Achieving 80-85% coverage
1
2
3
4
5
6
With domain
logic extraction
Dependency
injection with
constructors
Mock objects
using mockito
Powermock +
Mockito for
static classes **
Countdown
latches &
listeners for
threads
Presenter
pattern to
extract view
logic
Building the most comprehensive set of tests at unit level
Behavior tests with page object pattern
pattern comes in handy to modularize behavior tests and mimic flow relationshipsPage Object
Home screen
Product listing
Notifications
Orders
Execution
context
Asserting app behavior
Service
Stubs
Real
Service
APIs
can be used to address the coverage gap left by unit tests in AndroidEspresso
WireMock Mountebank Stubby
Making behavior tests effective
Turn on
‘don't keep
activities in
background’
Among all
others, run the
smallest
supported
emulator with
software
keyboard
Immediate
app
distribution
to alpha.
Hallway
testing
Multiple
emulators in
cloud or via
Docker images
across CI agents
Keep behavior tests lean, quick and focused on happy path
Testing the service contract
Actual
Service/APIs
Contract
Tests
Service
Stubs
Contract tests run typically few times a day. A stub replaces remote service for
behavior tests to keep tests responsive, stable and predictable.
Every commit
Periodically
Testing cross app flows
is a great starting place to orchestrate tests across apps
Uber engineering blog
Octopus by Uber
Consumer app
Warehouse app
Consumer on iOS
Orchestrator
Thanks for pulling through!
priyaaank

More Related Content

What's hot (20)

PDF
Meetup kickoff slides - Perfecto Mobile, September 2014
Perfecto Mobile
 
PPTX
Mobile test automation perfecto star east
Perfecto Mobile
 
PPT
Mobile applications and automation testing
IndicThreads
 
PDF
T Bytes Agile & AI Operations
EGBG Services
 
PDF
Experitest & Hexaware Co-Webinar
Experitest
 
PPTX
Testing Apps for Wearables
Perfecto by Perforce
 
PDF
Learnings from Mobile Application Testing
Thoughtworks
 
PPT
Cloud based Testing Mobile Apps
IndicThreads
 
PDF
Remove Bugs With API Testing Services
BugRaptors
 
PDF
Experitest & Cigniti Co-Webinar -
Experitest
 
PDF
Software QS Tag White Paper
Devendra Singh
 
PPTX
Everything You Need to Know About Testing Foldable Phones
Perfecto by Perforce
 
PPTX
Mobile Testing in the Cloud
Keynote Mobile Testing
 
PDF
7 use cases of real device testing
headspin2
 
PPTX
apidays LIVE New York 2021 - Playing with FHIR without getting burned by Dav...
apidays
 
PPT
Sqgo Ip
brucewarila
 
PPTX
Telerik Platform
Noam Kfir
 
PPTX
Continuous Mobile Testing Using Jenkins - A How To Guide
KeynoteSystems
 
PDF
Mobile Test Automation
Lee Barnes
 
DOCX
Eldhose_Resume
Eldhose M Babu
 
Meetup kickoff slides - Perfecto Mobile, September 2014
Perfecto Mobile
 
Mobile test automation perfecto star east
Perfecto Mobile
 
Mobile applications and automation testing
IndicThreads
 
T Bytes Agile & AI Operations
EGBG Services
 
Experitest & Hexaware Co-Webinar
Experitest
 
Testing Apps for Wearables
Perfecto by Perforce
 
Learnings from Mobile Application Testing
Thoughtworks
 
Cloud based Testing Mobile Apps
IndicThreads
 
Remove Bugs With API Testing Services
BugRaptors
 
Experitest & Cigniti Co-Webinar -
Experitest
 
Software QS Tag White Paper
Devendra Singh
 
Everything You Need to Know About Testing Foldable Phones
Perfecto by Perforce
 
Mobile Testing in the Cloud
Keynote Mobile Testing
 
7 use cases of real device testing
headspin2
 
apidays LIVE New York 2021 - Playing with FHIR without getting burned by Dav...
apidays
 
Sqgo Ip
brucewarila
 
Telerik Platform
Noam Kfir
 
Continuous Mobile Testing Using Jenkins - A How To Guide
KeynoteSystems
 
Mobile Test Automation
Lee Barnes
 
Eldhose_Resume
Eldhose M Babu
 

Viewers also liked (17)

PPTX
Power llibre (1)
Passapagina
 
DOCX
San mateo tours (1)
Alejandro Leon Cerna
 
DOCX
12. film magazine covers analysis x3
Shanice1
 
PDF
IZVESTAJ - XVII POLIMARK DEČIJI SAJAM
Deciji Sajam
 
PPS
Papai Noel
guest55f64184
 
PPTX
Avance de obra julio 2015
Spazios Es Vivir Bien
 
PPTX
Joseph b-day #2
slycath
 
PPTX
Ppt paper 8
Bhattizarna10
 
PDF
CMI pede ao governo colombiano que proteja defensores de direitos humanos
Carolina Maciel
 
PPT
Dccsmf oct11-ml
Carl Haggerty
 
PDF
Hackathon_article
Natasha Azar
 
ZIP
What is AdTaily
Marcin Grodzicki
 
PPTX
Présentation AFTAA - Paris Grain Day / Kim BENNI
Kim Benni
 
PDF
AI chatbots conversational interface: перспективы для развития финтеха и иншу...
Dima Arkas
 
PPTX
Teaching English as a Second Language in India Focus on Objectives by Shivend...
Parth Bhatt
 
PDF
Презентация "Английский для детей"
EnglishDom
 
PPT
Christmas traditions
EnglishDom
 
Power llibre (1)
Passapagina
 
San mateo tours (1)
Alejandro Leon Cerna
 
12. film magazine covers analysis x3
Shanice1
 
IZVESTAJ - XVII POLIMARK DEČIJI SAJAM
Deciji Sajam
 
Papai Noel
guest55f64184
 
Avance de obra julio 2015
Spazios Es Vivir Bien
 
Joseph b-day #2
slycath
 
Ppt paper 8
Bhattizarna10
 
CMI pede ao governo colombiano que proteja defensores de direitos humanos
Carolina Maciel
 
Dccsmf oct11-ml
Carl Haggerty
 
Hackathon_article
Natasha Azar
 
What is AdTaily
Marcin Grodzicki
 
Présentation AFTAA - Paris Grain Day / Kim BENNI
Kim Benni
 
AI chatbots conversational interface: перспективы для развития финтеха и иншу...
Dima Arkas
 
Teaching English as a Second Language in India Focus on Objectives by Shivend...
Parth Bhatt
 
Презентация "Английский для детей"
EnglishDom
 
Christmas traditions
EnglishDom
 
Ad

Similar to Scaling mobile dev teams (20)

PDF
Aditya_kapur_(Resume).PDF
Aditya Kapur
 
PPT
IBM Innovate DevOps for Mobile Apps
Sanjeev Sharma
 
PPTX
S cube's mobile application development
arti yadav
 
PPTX
Scube's mobile application development
arti yadav
 
PDF
2018 Pivotal DevOps Day_마이크로서비스 전환 방법론과 사례
VMware Tanzu Korea
 
PDF
2018 Pivotal DevOps Day_Pivotal 소개 및 세션 아젠다 소개
VMware Tanzu Korea
 
PPSX
Create engaging mobile experiences with Visual Studio, Microsoft Azure and Xa...
Mukteswar Patnaik
 
PPTX
Twelve factor-app
José Javier Vélez Colón
 
PPTX
Mobile DevTest Dictionary
Perfecto by Perforce
 
PDF
IRJET- Cross-Platform Supported E-Learning Mobile Application
IRJET Journal
 
PDF
A Complete Step-by-Step Guide to Mobile App Performance Testing.pdf
Steve Wortham
 
DOC
Resumeupdated
venkatanarayanavudugundla
 
DOC
Resumeupdated
venkatanarayanavudugundla
 
PDF
App Architecture for Efficient Mobile App Development.pdf
iDataScientists
 
PDF
Mobility Solutions - Development of Hybrid Mobile Applications with HTML
Mindteck (India) Limited
 
PDF
Enabling Continuous Quality in Mobile App Development
Matthew Young
 
DOCX
Naresh Chirra
naresh chirra
 
PPT
2011 Artezio Mobile
polatsidis
 
PDF
Soa architect summit mobile 2013_mar [compatibility mode]
Sreeni Pamidala
 
PDF
Experitest & Tech Mahindra Co-Webinar
Experitest
 
Aditya_kapur_(Resume).PDF
Aditya Kapur
 
IBM Innovate DevOps for Mobile Apps
Sanjeev Sharma
 
S cube's mobile application development
arti yadav
 
Scube's mobile application development
arti yadav
 
2018 Pivotal DevOps Day_마이크로서비스 전환 방법론과 사례
VMware Tanzu Korea
 
2018 Pivotal DevOps Day_Pivotal 소개 및 세션 아젠다 소개
VMware Tanzu Korea
 
Create engaging mobile experiences with Visual Studio, Microsoft Azure and Xa...
Mukteswar Patnaik
 
Twelve factor-app
José Javier Vélez Colón
 
Mobile DevTest Dictionary
Perfecto by Perforce
 
IRJET- Cross-Platform Supported E-Learning Mobile Application
IRJET Journal
 
A Complete Step-by-Step Guide to Mobile App Performance Testing.pdf
Steve Wortham
 
App Architecture for Efficient Mobile App Development.pdf
iDataScientists
 
Mobility Solutions - Development of Hybrid Mobile Applications with HTML
Mindteck (India) Limited
 
Enabling Continuous Quality in Mobile App Development
Matthew Young
 
Naresh Chirra
naresh chirra
 
2011 Artezio Mobile
polatsidis
 
Soa architect summit mobile 2013_mar [compatibility mode]
Sreeni Pamidala
 
Experitest & Tech Mahindra Co-Webinar
Experitest
 
Ad

Recently uploaded (20)

PPT
Interview paper part 3, It is based on Interview Prep
SoumyadeepGhosh39
 
PDF
Timothy Rottach - Ramp up on AI Use Cases, from Vector Search to AI Agents wi...
AWS Chicago
 
PDF
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
PDF
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
PDF
HCIP-Data Center Facility Deployment V2.0 Training Material (Without Remarks ...
mcastillo49
 
PDF
CIFDAQ Market Insights for July 7th 2025
CIFDAQ
 
PDF
The Builder’s Playbook - 2025 State of AI Report.pdf
jeroen339954
 
PDF
CIFDAQ Token Spotlight for 9th July 2025
CIFDAQ
 
PDF
July Patch Tuesday
Ivanti
 
PPTX
WooCommerce Workshop: Bring Your Laptop
Laura Hartwig
 
PDF
CIFDAQ Weekly Market Wrap for 11th July 2025
CIFDAQ
 
PDF
Empower Inclusion Through Accessible Java Applications
Ana-Maria Mihalceanu
 
PDF
NewMind AI - Journal 100 Insights After The 100th Issue
NewMind AI
 
PDF
SWEBOK Guide and Software Services Engineering Education
Hironori Washizaki
 
PDF
Presentation - Vibe Coding The Future of Tech
yanuarsinggih1
 
PDF
"AI Transformation: Directions and Challenges", Pavlo Shaternik
Fwdays
 
PDF
Windsurf Meetup Ottawa 2025-07-12 - Planning Mode at Reliza.pdf
Pavel Shukhman
 
PPTX
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
PDF
HubSpot Main Hub: A Unified Growth Platform
Jaswinder Singh
 
PPTX
Webinar: Introduction to LF Energy EVerest
DanBrown980551
 
Interview paper part 3, It is based on Interview Prep
SoumyadeepGhosh39
 
Timothy Rottach - Ramp up on AI Use Cases, from Vector Search to AI Agents wi...
AWS Chicago
 
Smart Trailers 2025 Update with History and Overview
Paul Menig
 
"Beyond English: Navigating the Challenges of Building a Ukrainian-language R...
Fwdays
 
HCIP-Data Center Facility Deployment V2.0 Training Material (Without Remarks ...
mcastillo49
 
CIFDAQ Market Insights for July 7th 2025
CIFDAQ
 
The Builder’s Playbook - 2025 State of AI Report.pdf
jeroen339954
 
CIFDAQ Token Spotlight for 9th July 2025
CIFDAQ
 
July Patch Tuesday
Ivanti
 
WooCommerce Workshop: Bring Your Laptop
Laura Hartwig
 
CIFDAQ Weekly Market Wrap for 11th July 2025
CIFDAQ
 
Empower Inclusion Through Accessible Java Applications
Ana-Maria Mihalceanu
 
NewMind AI - Journal 100 Insights After The 100th Issue
NewMind AI
 
SWEBOK Guide and Software Services Engineering Education
Hironori Washizaki
 
Presentation - Vibe Coding The Future of Tech
yanuarsinggih1
 
"AI Transformation: Directions and Challenges", Pavlo Shaternik
Fwdays
 
Windsurf Meetup Ottawa 2025-07-12 - Planning Mode at Reliza.pdf
Pavel Shukhman
 
Q2 FY26 Tableau User Group Leader Quarterly Call
lward7
 
HubSpot Main Hub: A Unified Growth Platform
Jaswinder Singh
 
Webinar: Introduction to LF Energy EVerest
DanBrown980551
 

Scaling mobile dev teams

  • 1. Patterns to scale mobile teams Using examples for Android Priyank Gupta Sahaj Software Solutions Pvt. Ltd.
  • 2. Mobile is eating the world
  • 3. Evolution in last 5 years Mobile Inclusive Mobile First Mobile Only
  • 4. Building it for 3.2 billion people 7.1 Billion - World population 7.9 Billion mobile devices 3.2 Billion Internet Users State of connectivity 2015 - Report Mobile users are the internet users
  • 5. Worldwide market-share Smartphone market share - Report Android iOS Others 83% 14% 03%
  • 6. Everything in ‘context’ Discovery DeliveryMedia Payments Aggregation Discovering content, deals, products, places and information happens based on location, context and conversations.. Payments, wallets, money transfers and currency conversions happens via mobile apps instantaneously. News doesn’t come from media houses. News is crowd sourced, crowd curated and pushed real-time to consumers on mobile. Delivery is done across diverse products and services; ordered, scheduled and tracked via mobile real-time. Services are aggregated and made available on mobile across all domains. Delivery, taxis, food, handy-work etc.
  • 7. Why mobile is different?
  • 8. Challenges Multiple platforms and form types No control on environment / device Work across version and device types Design with usability at center. Stay ahead of competing feature set Forced SDK update and different runtimes Dalvik, ART, Arm6, Arm7
  • 9. Survival for fittest Ideas Tons of ideas see daylight in an healthy ecosystem Saturation Redundant businesses cause saturation to occur Consolidation Consolidation in form of acquisition, mergers and natural death. Healthy co-existence Winning teams are lean, agile, ahead of competition and know how to scale.
  • 11. Things that matter Hiring & People Team organization Technology selection Development practices Scalable design Testing & Safety nets Release cycle & practices
  • 13. In business of delivering experience HTML5 Native Custom Bridges Cordova HTML5+ Service workers React Native Xamarin Selecting mobile implementation strategy Experience + Reach Cost Laser Cover your bases Long term strategy should focus on building a native experience. The journey can be gradual or with a jump start. No adoption No magic bullets
  • 15. Technology teams vs.. Release 1 - Mix of feature X & Y Android iOS Services Siloed by technology /platform If feature parity is important then lowest denominator goes into release Missed opportunity to optimize services based on common domain across platform Easier to draw boundaries. Initial velocity gain due to technical know how.
  • 16. .. Product team Release 1 - Feature X Release 1 - Feature Y Services iOS Android Initial velocity impact Shared understanding of product as a whole Feature parity maintained in releases Can get away with a leaner team. Problems solved once. Service design can have considerations for clients baked in right from start
  • 17. Handovers & feedback loops Development Design Testing Story started Story done Quicker feedback loops keeps the cost of change low and validates the shared understanding constantly.
  • 18. Services are part of product Services App Own services as first class deliverable Use patterns to decouple legacy services Leverage REST Level-3 characteristics to make service adaptive Use patterns to optimize services for target consumer platform
  • 20. Predictability & Consistency Where would you find the code to fetch details from database? Can you predict how someone on team would fetch images in background? Will everyone know how to find the service call you wrote? Can everyone on team predict what’s going to be covered in an espresso test? Do you know where to find the styling for a specific UI element? Using conventions you can build predictability on team to simplify mental models needed to understand the codebase
  • 21. Define the simple machines Screw Wheel & Axle Pulley Lever A simple machine can hammer in the basic principle and allow far more complex machines to be developed with coherence.
  • 22. Adopting patterns Persistence / db Web ServicesUI / Styles Debugging Invest time in first of everything. Build a team-wide definition and reuse the pattern to promote consistency and predictability. Background tasks / Services Device hardware
  • 23. Web service patterns for consistent service calls across features.Retrofit + Singletons + Observers Callback implementation for Retrofit API (Singleton) Retrofit service interface Observers Activities, fragments or services Data retrieved from service (possibly cached)
  • 24. External integrations patterns BFF approach | Adaptive API Adaptive API Backend for frontend Downstream systems Adaptive proxy APIs Consumer centric abstractions - BFFs for optimal experience of services on devicesAdaptive APIs BFFsor
  • 25. for consistent execution of short async tasksAsync task wrapper + Observers Thread (Pools)or Asynchronous tasks patterns Obtain instance Set data Fire task Check references Call observers Die or loop Main thread Spawned/Pooled thread
  • 26. Scaling commits with patterns Feature one Feature two Master Feature toggles explained vs Requires complex CI setup to constantly identify and merge branches and test state at any point of time. Requires building a feature toggle functionality with dynamic toggles and tests to validate all feasible path. Master Feature one toggled off Feature two toggled off Feature two toggled on Feature one toggled on
  • 27. Debugging and logging patterns Force upgrade Debug console Thread local logging Crashlytics Build consistent set of practices to debug issues using Debug console Crashlytics Thread logging
  • 29. TDD - Achieving 80-85% coverage 1 2 3 4 5 6 With domain logic extraction Dependency injection with constructors Mock objects using mockito Powermock + Mockito for static classes ** Countdown latches & listeners for threads Presenter pattern to extract view logic Building the most comprehensive set of tests at unit level
  • 30. Behavior tests with page object pattern pattern comes in handy to modularize behavior tests and mimic flow relationshipsPage Object Home screen Product listing Notifications Orders Execution context
  • 31. Asserting app behavior Service Stubs Real Service APIs can be used to address the coverage gap left by unit tests in AndroidEspresso WireMock Mountebank Stubby
  • 32. Making behavior tests effective Turn on ‘don't keep activities in background’ Among all others, run the smallest supported emulator with software keyboard Immediate app distribution to alpha. Hallway testing Multiple emulators in cloud or via Docker images across CI agents Keep behavior tests lean, quick and focused on happy path
  • 33. Testing the service contract Actual Service/APIs Contract Tests Service Stubs Contract tests run typically few times a day. A stub replaces remote service for behavior tests to keep tests responsive, stable and predictable. Every commit Periodically
  • 34. Testing cross app flows is a great starting place to orchestrate tests across apps Uber engineering blog Octopus by Uber Consumer app Warehouse app Consumer on iOS Orchestrator
  • 35. Thanks for pulling through! priyaaank