SlideShare una empresa de Scribd logo
1 de 32
1
Faster Better Cheaper in a
highly regulated environment?
Craeg Strong
CTO, Ariel Partners
October 15, 2018
Washington, DC
© Copyright Ariel Partners 2018 *sales@arielpartners.com ((646) 467-7394
2
Agenda
Context
A. Prior Work
B. Selected Engagement Details
1. Agile Requirements Decomposition via User Stories
2. Applying the Kanban Method
C. Observations and Discoveries
1. Ongoing Challenges
2. Lessons Learned and Takeaways
3
Craeg Strong
Software Development since 1988
Large Commercial & Government Projects
Agile Coach / DevOps Engineer
Kanban Trainer / SpecFlow Trainer
Performance & Scalability Architect
Certified Ethical Hacker
New York & Washington DC Area
CTO, Ariel Partners
AKT, KMP, CSM, CSP, CSPO,
ITILv3, PMI-ACP, PMP, LeSS, SAFe
www.arielpartners.com
cstrong@arielpartners.com
@ckstrong1
4
Energy Company
5
Unique Challenges for Energy Sector
Highly Constrained COTS Product
Few Developers With Deep Domain and Product Knowledge
Lengthy Analysis Required
Customers Often Unavailable
Highly Distributed Organization
A. PRIOR KANBAN IMPLEMENTATION
7
Initial Kanban Implementation
1. Established LeanKit to track the work
2. Process captured as-is, no changes
3. No changes to existing responsibilities or titles
Consultant helped IT teams implement Kanban in early 2017
Before Kanban
SharePoint
Functional Requirements Document
System Design Document
Detailed Design Document
User & Admin Guides
Analyze Design Build Test Deploy
With Kanban
A) No Changes To
Documentation
B) Requirements
Captured on
Cards
C) Kanban board
lanes reflect
process steps
Minimum
Marketable
Feature
8
Minimum Marketable Features
Minimum As small as possible. If an MMF can be subdivided into
multiple MMFs, it should be– even if those MMFs are
to be delivered together.
Marketable Something that could be potentially deployed on its
own (used in production, with live data)
Feature Something that is perceived, of itself, as value by the
user.
Minimum Marketable Features. The smallest set of functionality that must be
realized in order for the customer to perceive value. A “MMF” is characterized
by the three attributes: minimum, marketable, and feature.
9
Initial LeanKit Implementation
HypercareBacklog Deploy
System /
User Test
Build /
Unit Test
Func
Design
Reqs
Analysis
Approval
10
Development Process
Back Office
Demand
Middle Office
Front Office
Governance
Committee
Analysis
Committed&
SequencedQueue
Uncommitted
Arrivals
Backlog
Analysts Developers Testers
Hypercare
Average 120+ Days (!!!)
Approval
Gate
IT
Need to
Do Better
Analysts Play
Both Roles
Other
11
Kanban Foundational Principles
1. Start with What you do Now
2. Agree to Pursue Incremental, Evolutionary
Change
3. (Initially) Respect the Current Process,
Roles, Responsibilities & Titles
Hmmm, we
got stuck on
this one
B. INCREMENTAL IMPROVEMENTS
B1. REQUIREMENTS DECOMPOSITION
14
As Is versus To Be
As Is
Delivered
MMF
Lengthy Delays
Lack of Visible Progress
Kanban Board not adding value
Difficult to Estimate
Difficult to Subdivide
Identified
Minimum
Marketable
Feature
User
Story
User
Story
SpikeSpike
 Regular Visible Progress
 Kanban Board tells a story
 Small, estimable chunks
 Independently valuable stories
 Can assign work to multiple teams
To Be
Delivered
MMF
User
Story
Idea or
Request
Identified
Minimum
Marketable
Feature
15
Decomposing MMF into User Stories…
MMF User Story
Relationship Parent Child
Effort 2 weeks to 4 months of
development
2 days to 2 weeks
Analysis Requirements Document As a/I want/So that
Possibly a UX mockup
Testing Test Plan (up to dozens of
tests)
2-12 Acceptance Criteria
Value to Business Immediately recognized as
independently valuable
Has value to the business,
but the value may be best
realized when combined
with other user stories split
out from the MMF
16
…and Spikes
User Story Spike
Goal Realize business value Reduce risk by answering a
question or gathering information
Effort 2 days to 2 weeks 2 days to 2 weeks
Completion Acceptance Criteria fulfilled Hypothesis is proven true or false
Next Steps Testing, Documentation,
Deployment
Discarded or recycled
17
Properly Formed User Stories
Splitting User Stories
1. Performance (ways to add caching or improved performance)
2. Simple to complex
3. Interface variations: excel, grid, graphical, mobile,
4. Variations in data: geographic region, or by refinery, or by customer
5. Operations: splitting out CRUD
6. Business rule variations
7. Workflow steps: this then that
8. Breakout a spike
INVEST
1. Independent
2. Negotiable
3. Valuable
4. Estimable
5. Small
6. Testable
User Story Components
1. “As a…” Identify the Stakeholder. More than one? Split!
2. “I want…” Identity the function the way the stakeholder would
3. “So that…” Identify the business value. What is the Stakeholder’s goal?
4. Acceptance Criteria
1. Assumptions
2. Invariants
3. Pre- and Post-Conditions
18
Example #1: EBITDA
Story Compute Operating Income component of EBITDA by company
Story Compute Income Tax component of EBITDA by company
Story Compute Depreciation component of EBITDA by company
Story Compute Interest component of EBITDA by company
Story Compute Amortization component of EBITDA by company
Story Compute EBITDA by company combining component calculations
Story Control Access to EBITDA calculations by company
Story Reconciliation report to compare EBITDA in AO report to BPC P&L
statement
Story Schedule report to enable reconciliation during close
MMF Description
EBITDA Calculations by Company – for
Accounting and Reporting Team
Earnings before interest taxes depreciation and amortization
19
Example #2: Trader Checkout Process
Story Basic read-only details view for trader for formula tablet Similar to existing report, but omits trades already
approved or rejected, activated or pending. Most
trades have formula tablets
Story Trader can approve or reject deal details
Story Trader can only approve/reject their own trades
Story Read-only form for middle office to review rejected details
Story Force modified deals to be re-approved
Story Update historical deal details so I don’t have to approve
them
Spike Determine how fixed price tablets will be displayed Small percentage of trades have fixed price tablets
Story Support fixed price tablet support for TCM view
MMF Description
New Trader Checkout Process (TCM) For Audit To prevent booking errors, have traders explicitly approve or reject
trades on a daily basis before they are activated
B2. APPLYING THE KANBAN METHOD*
*STATIK: SYSTEMS THINKING APPROACH TO IMPLEMENTING KANBAN
21
1. Leading Questions
2. Motivations for Change
3. Analyze Sources and Nature of Demand
4. Identify and Define Classes of Service
5. Analyze Delivery Capability
6. Model Delivery Workflow
7. Kanban System Design (Lane Policies, WIP Limits, Replenishment
Cycles, etc.)
Applying the Kanban Method
22
Motivations For Change
Internal Dissatisfaction
Work beginning on MMF but card is stuck “waiting for approval”
Significant time spent on documentation (Reqs doc, Func spec, Tech spec)
Not much day-by-day movement on the board
Large projects do not appear on the board
No visibility Into Work Being done for MMF
Difficult to tell what is blocked or high priority
Coordination with Other Groups (e.g. Help Desk) not reflected on board
How Can I tell what has moved since last week?
External Dissatisfaction
Too slow / Long lead time
Unpredictable delivery
Quality issues
23
Updated LeanKit Board Design
Backlog Approval
Reqs
Analysis
Func
Design
Build /
Unit Test
System /
User Test
Deploy Hypercare
Previous Flow
Hypercare
DefectsUser Stories & Spikes
Backlog
On
Deck
Reqs
Analysis
Design /
Build
System
Test
User Test Deploy Hypercare
Specify Ready
In
Progress
Func
Test Identify
In
Progress
Test Deploy
Updated Flow
© Copyright Ariel Partners 2018 *sales@arielpartners.com
((646) 467-7394
24
Updated Board
25
On Deck Lanes: Two MMFs Per Stakeholder Group
All Five Stakeholder
Groups Can Indicate
their Top Two
Priorities
Top Two Can Change
Anytime Prior To
Commitment
26
Parallel Parent[MMF] and Child[User Story] Work
Child Stories Created
When MMF Analysis
Begins
“Ready” User Stories
Can Be Completed
Anytime
Additional User
Stories Created As
Needed During
MMF Analysis &
Design
Spikes Created As
Needed
Finish-to-Finish Dependency (MMF to Child Story)
27
Hypercare Defects Captured
External Defects
Appear Directly
Under Their Parent
MMF
Separate Card Type
(Hypercare vs
Internal Defect)
Makes Querying
Easy
28
Improving Functional / Technical Team
Collaboration
Functional
Team
Technical
team
Handoff
From This…
Time
Level
Of
Effort
MMF Reqs
Analysis
MMF Design
& Build
… To This!
Functional Technical
Level
Of
Effort
Time
Story
Identification
Story
In Progress
MMF
Design
MMF
Reqs Analysis
Explicit
Entry/Exit
Policies
Explicit
Entry/Exit
Policies
Explicit
Entry/Exit
Policies
C. ONGOING CHALLENGES &
LESSONS LEARNED
30
Lessons Learned for Highly Regulated / COTS / Energy
Challenge Response
1. Spikes frequently needed to explore different designs
2. Estimation process helps team identify areas of
significant uncertainty and risk (Extra-Large “T” Shirt)
Older Development Platform,
Largely Manual Processes
Development takes longer; user stories must be split
more fine-grained
Highly Specialized Team
Members Not Fungible
Benefits from “swarming” and collaboration are limited,
often leading to increased Work In Progress
Stakeholders Unavailable for
Extended Periods of Time
Identify backup stakeholders & More Up-Front Estimation
and Planning Required to avoid Blackout times
Highly Complex Commercial
Software Package
31
Takeaways
Kanban Well-Suited for “Highly Constrained” SW Development
Low Barrier to Entry
Transparency Promotes Trust
Highlights Sources of Delay
Conducive to Incremental Change
Compatible with SDLC methods (Waterfall, Scrum, SAFe, etc.)
Kanban Method and STATIK
Simple and Powerful Techniques
Helps Break down Barriers and Encourage Collaboration
Limiting the amount of Work in Process reduces Overburdening
Improvement Workshops can be repeated as needed
32
Discussions, Q & A
© Copyright Ariel Partners 2018 *sales@arielpartners.com ((646) 467-7394
Craeg Strong
Savant Financial Technologies, Inc.
d/b/a Ariel Partners
Cell: (917) 992-0259
cstrong@arielpartners.com
www.arielpartners.com
@arielpartners
Thank You!

Más contenido relacionado

Similar a 20181016 Agile DC 2018 Conf Kanban Case Study for Energy Company

Mark Foley Agile Methods And The Business Analystc
Mark Foley   Agile Methods And The Business AnalystcMark Foley   Agile Methods And The Business Analystc
Mark Foley Agile Methods And The Business AnalystcMia Horrigan
 
Simplifying the Complexity of Salesforce CPQ: Tips & Best Practices
Simplifying the Complexity of Salesforce CPQ: Tips & Best PracticesSimplifying the Complexity of Salesforce CPQ: Tips & Best Practices
Simplifying the Complexity of Salesforce CPQ: Tips & Best Practicespanayaofficial
 
Shorten Your Development Time with an Extensible Design for Apex
Shorten Your Development Time with an Extensible Design for ApexShorten Your Development Time with an Extensible Design for Apex
Shorten Your Development Time with an Extensible Design for ApexSalesforce Developers
 
Advanced Execution Concepts in Branch and Teller Capture
Advanced Execution Concepts in Branch and Teller CaptureAdvanced Execution Concepts in Branch and Teller Capture
Advanced Execution Concepts in Branch and Teller CaptureVivastream
 
Sasidhar_ 5+ yrs_Testing Profile
Sasidhar_ 5+ yrs_Testing ProfileSasidhar_ 5+ yrs_Testing Profile
Sasidhar_ 5+ yrs_Testing ProfileSasidhar Reddy
 
Managing an Experimentation Platform by LinkedIn Product Leader
Managing an Experimentation Platform by LinkedIn Product LeaderManaging an Experimentation Platform by LinkedIn Product Leader
Managing an Experimentation Platform by LinkedIn Product LeaderProduct School
 
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...NGA Human Resources
 
Priti - ETL Engineer
Priti - ETL EngineerPriti - ETL Engineer
Priti - ETL Engineerpriti kumari
 
Karan Singh Updated Resume
Karan Singh Updated ResumeKaran Singh Updated Resume
Karan Singh Updated Resume306massa
 

Similar a 20181016 Agile DC 2018 Conf Kanban Case Study for Energy Company (20)

Pravin_CV_4+years
Pravin_CV_4+yearsPravin_CV_4+years
Pravin_CV_4+years
 
Resume
ResumeResume
Resume
 
Resume_Presious
Resume_PresiousResume_Presious
Resume_Presious
 
Mark Foley Agile Methods And The Business Analystc
Mark Foley   Agile Methods And The Business AnalystcMark Foley   Agile Methods And The Business Analystc
Mark Foley Agile Methods And The Business Analystc
 
Simplifying the Complexity of Salesforce CPQ: Tips & Best Practices
Simplifying the Complexity of Salesforce CPQ: Tips & Best PracticesSimplifying the Complexity of Salesforce CPQ: Tips & Best Practices
Simplifying the Complexity of Salesforce CPQ: Tips & Best Practices
 
Shorten Your Development Time with an Extensible Design for Apex
Shorten Your Development Time with an Extensible Design for ApexShorten Your Development Time with an Extensible Design for Apex
Shorten Your Development Time with an Extensible Design for Apex
 
Advanced Execution Concepts in Branch and Teller Capture
Advanced Execution Concepts in Branch and Teller CaptureAdvanced Execution Concepts in Branch and Teller Capture
Advanced Execution Concepts in Branch and Teller Capture
 
Resume astha.
Resume astha.Resume astha.
Resume astha.
 
Reqs analysis
Reqs analysisReqs analysis
Reqs analysis
 
Sasidhar_ 5+ yrs_Testing Profile
Sasidhar_ 5+ yrs_Testing ProfileSasidhar_ 5+ yrs_Testing Profile
Sasidhar_ 5+ yrs_Testing Profile
 
Managing an Experimentation Platform by LinkedIn Product Leader
Managing an Experimentation Platform by LinkedIn Product LeaderManaging an Experimentation Platform by LinkedIn Product Leader
Managing an Experimentation Platform by LinkedIn Product Leader
 
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...
Top Tips for Getting the Best from SuccessFactors Q2 2016 Release Universal ...
 
Priti - ETL Engineer
Priti - ETL EngineerPriti - ETL Engineer
Priti - ETL Engineer
 
Summer '18 Developer Highlights
Summer '18 Developer HighlightsSummer '18 Developer Highlights
Summer '18 Developer Highlights
 
Rohit_CV
Rohit_CVRohit_CV
Rohit_CV
 
Dhananjayulu Neeli_CV
Dhananjayulu Neeli_CVDhananjayulu Neeli_CV
Dhananjayulu Neeli_CV
 
Automated legacy portfolio assessment
Automated legacy portfolio assessmentAutomated legacy portfolio assessment
Automated legacy portfolio assessment
 
Gears agile
Gears agileGears agile
Gears agile
 
Chandrashekhar resume
Chandrashekhar resumeChandrashekhar resume
Chandrashekhar resume
 
Karan Singh Updated Resume
Karan Singh Updated ResumeKaran Singh Updated Resume
Karan Singh Updated Resume
 

Más de Craeg Strong

20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...
20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...
20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...Craeg Strong
 
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONS
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONSRESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONS
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONSCraeg Strong
 
20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And ExecutivesCraeg Strong
 
20231004 JiraCon Team Spaces In Confluence
20231004 JiraCon Team Spaces In Confluence20231004 JiraCon Team Spaces In Confluence
20231004 JiraCon Team Spaces In ConfluenceCraeg Strong
 
20231023 AgileDC Making Strategy Real with Well Crafted Outcomes
20231023 AgileDC Making Strategy Real with Well Crafted Outcomes20231023 AgileDC Making Strategy Real with Well Crafted Outcomes
20231023 AgileDC Making Strategy Real with Well Crafted OutcomesCraeg Strong
 
20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And ExecutivesCraeg Strong
 
20230622 PMINYC Modern Project Management with Lean Kanban
20230622 PMINYC Modern Project Management with Lean Kanban20230622 PMINYC Modern Project Management with Lean Kanban
20230622 PMINYC Modern Project Management with Lean KanbanCraeg Strong
 
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...Craeg Strong
 
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based System
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based SystemADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based System
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based SystemCraeg Strong
 
Coaching leaders: how to get it right, and how to get it really, really wrong
Coaching leaders: how to get it right, and how to get it really, really wrongCoaching leaders: how to get it right, and how to get it really, really wrong
Coaching leaders: how to get it right, and how to get it really, really wrongCraeg Strong
 
20220607 Introduction to Flight Levels
20220607 Introduction to Flight Levels20220607 Introduction to Flight Levels
20220607 Introduction to Flight LevelsCraeg Strong
 
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...Craeg Strong
 
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...Craeg Strong
 
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...Craeg Strong
 
20220329 Ariel Partners Configuring Jira For Maximum Agility
20220329 Ariel Partners Configuring Jira For Maximum Agility20220329 Ariel Partners Configuring Jira For Maximum Agility
20220329 Ariel Partners Configuring Jira For Maximum AgilityCraeg Strong
 
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...Craeg Strong
 
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...Craeg Strong
 
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...Craeg Strong
 
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...Craeg Strong
 
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel PartnersCraeg Strong
 

Más de Craeg Strong (20)

20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...
20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...
20231019 Flight Levels Bosch Engagement Day 2023 Business Agility With Flight...
 
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONS
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONSRESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONS
RESPONSIVE TRAINING FOR DIGITAL TRANSFORMATIONS
 
20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives
 
20231004 JiraCon Team Spaces In Confluence
20231004 JiraCon Team Spaces In Confluence20231004 JiraCon Team Spaces In Confluence
20231004 JiraCon Team Spaces In Confluence
 
20231023 AgileDC Making Strategy Real with Well Crafted Outcomes
20231023 AgileDC Making Strategy Real with Well Crafted Outcomes20231023 AgileDC Making Strategy Real with Well Crafted Outcomes
20231023 AgileDC Making Strategy Real with Well Crafted Outcomes
 
20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives20230829 DAFITC 2023 Agile For Leaders And Executives
20230829 DAFITC 2023 Agile For Leaders And Executives
 
20230622 PMINYC Modern Project Management with Lean Kanban
20230622 PMINYC Modern Project Management with Lean Kanban20230622 PMINYC Modern Project Management with Lean Kanban
20230622 PMINYC Modern Project Management with Lean Kanban
 
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...
20230622 PMIC Leveraging the 4 Disciplines of Execution & Enterprise Kanban t...
 
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based System
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based SystemADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based System
ADDO 2022 Putting the Sec in DevSecOps for an AWS Lambda Based System
 
Coaching leaders: how to get it right, and how to get it really, really wrong
Coaching leaders: how to get it right, and how to get it really, really wrongCoaching leaders: how to get it right, and how to get it really, really wrong
Coaching leaders: how to get it right, and how to get it really, really wrong
 
20220607 Introduction to Flight Levels
20220607 Introduction to Flight Levels20220607 Introduction to Flight Levels
20220607 Introduction to Flight Levels
 
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...
20220824 Kanban Global Summit 2022 Now You See It! Observing Flow Using [ONLI...
 
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...
20220621 Project Management Innovation Conference Harrisburg PA Seatbelts and...
 
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...
20220216 Lean In Government Conference Harrisburg PA Agile Tool Clash of the ...
 
20220329 Ariel Partners Configuring Jira For Maximum Agility
20220329 Ariel Partners Configuring Jira For Maximum Agility20220329 Ariel Partners Configuring Jira For Maximum Agility
20220329 Ariel Partners Configuring Jira For Maximum Agility
 
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...
20220301 Atlassian Team Tour Government ArielPartners Innovative Jira Configu...
 
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...
20211202 North America DevOps Group NADOG Adapting to Covid With Serverless C...
 
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...
20211007 PMI LIC Chapter Agile Tool Celebrity Death Match Kanbanize vs Jira C...
 
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...
20211114 Agile DevOps East Conf 2021 Bringing DevOps to an Entrenched Legacy ...
 
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners
20211028 ADDO Adapting to Covid with Serverless Craeg Strong Ariel Partners
 

Último

Large Language Models for Test Case Evolution and Repair
Large Language Models for Test Case Evolution and RepairLarge Language Models for Test Case Evolution and Repair
Large Language Models for Test Case Evolution and RepairLionel Briand
 
Amazon Bedrock in Action - presentation of the Bedrock's capabilities
Amazon Bedrock in Action - presentation of the Bedrock's capabilitiesAmazon Bedrock in Action - presentation of the Bedrock's capabilities
Amazon Bedrock in Action - presentation of the Bedrock's capabilitiesKrzysztofKkol1
 
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsSensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsChristian Birchler
 
Best Angular 17 Classroom & Online training - Naresh IT
Best Angular 17 Classroom & Online training - Naresh ITBest Angular 17 Classroom & Online training - Naresh IT
Best Angular 17 Classroom & Online training - Naresh ITmanoharjgpsolutions
 
Precise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalPrecise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalLionel Briand
 
Understanding Flamingo - DeepMind's VLM Architecture
Understanding Flamingo - DeepMind's VLM ArchitectureUnderstanding Flamingo - DeepMind's VLM Architecture
Understanding Flamingo - DeepMind's VLM Architecturerahul_net
 
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full Recording
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full RecordingOpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full Recording
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full RecordingShane Coughlan
 
Patterns for automating API delivery. API conference
Patterns for automating API delivery. API conferencePatterns for automating API delivery. API conference
Patterns for automating API delivery. API conferencessuser9e7c64
 
Powering Real-Time Decisions with Continuous Data Streams
Powering Real-Time Decisions with Continuous Data StreamsPowering Real-Time Decisions with Continuous Data Streams
Powering Real-Time Decisions with Continuous Data StreamsSafe Software
 
Zer0con 2024 final share short version.pdf
Zer0con 2024 final share short version.pdfZer0con 2024 final share short version.pdf
Zer0con 2024 final share short version.pdfmaor17
 
SAM Training Session - How to use EXCEL ?
SAM Training Session - How to use EXCEL ?SAM Training Session - How to use EXCEL ?
SAM Training Session - How to use EXCEL ?Alexandre Beguel
 
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...Bert Jan Schrijver
 
eSoftTools IMAP Backup Software and migration tools
eSoftTools IMAP Backup Software and migration toolseSoftTools IMAP Backup Software and migration tools
eSoftTools IMAP Backup Software and migration toolsosttopstonverter
 
Salesforce Implementation Services PPT By ABSYZ
Salesforce Implementation Services PPT By ABSYZSalesforce Implementation Services PPT By ABSYZ
Salesforce Implementation Services PPT By ABSYZABSYZ Inc
 
VictoriaMetrics Q1 Meet Up '24 - Community & News Update
VictoriaMetrics Q1 Meet Up '24 - Community & News UpdateVictoriaMetrics Q1 Meet Up '24 - Community & News Update
VictoriaMetrics Q1 Meet Up '24 - Community & News UpdateVictoriaMetrics
 
Introduction to Firebase Workshop Slides
Introduction to Firebase Workshop SlidesIntroduction to Firebase Workshop Slides
Introduction to Firebase Workshop Slidesvaideheekore1
 
Ronisha Informatics Private Limited Catalogue
Ronisha Informatics Private Limited CatalogueRonisha Informatics Private Limited Catalogue
Ronisha Informatics Private Limited Catalogueitservices996
 
UI5ers live - Custom Controls wrapping 3rd-party libs.pptx
UI5ers live - Custom Controls wrapping 3rd-party libs.pptxUI5ers live - Custom Controls wrapping 3rd-party libs.pptx
UI5ers live - Custom Controls wrapping 3rd-party libs.pptxAndreas Kunz
 
Leveraging AI for Mobile App Testing on Real Devices | Applitools + Kobiton
Leveraging AI for Mobile App Testing on Real Devices | Applitools + KobitonLeveraging AI for Mobile App Testing on Real Devices | Applitools + Kobiton
Leveraging AI for Mobile App Testing on Real Devices | Applitools + KobitonApplitools
 
Post Quantum Cryptography – The Impact on Identity
Post Quantum Cryptography – The Impact on IdentityPost Quantum Cryptography – The Impact on Identity
Post Quantum Cryptography – The Impact on Identityteam-WIBU
 

Último (20)

Large Language Models for Test Case Evolution and Repair
Large Language Models for Test Case Evolution and RepairLarge Language Models for Test Case Evolution and Repair
Large Language Models for Test Case Evolution and Repair
 
Amazon Bedrock in Action - presentation of the Bedrock's capabilities
Amazon Bedrock in Action - presentation of the Bedrock's capabilitiesAmazon Bedrock in Action - presentation of the Bedrock's capabilities
Amazon Bedrock in Action - presentation of the Bedrock's capabilities
 
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving CarsSensoDat: Simulation-based Sensor Dataset of Self-driving Cars
SensoDat: Simulation-based Sensor Dataset of Self-driving Cars
 
Best Angular 17 Classroom & Online training - Naresh IT
Best Angular 17 Classroom & Online training - Naresh ITBest Angular 17 Classroom & Online training - Naresh IT
Best Angular 17 Classroom & Online training - Naresh IT
 
Precise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive GoalPrecise and Complete Requirements? An Elusive Goal
Precise and Complete Requirements? An Elusive Goal
 
Understanding Flamingo - DeepMind's VLM Architecture
Understanding Flamingo - DeepMind's VLM ArchitectureUnderstanding Flamingo - DeepMind's VLM Architecture
Understanding Flamingo - DeepMind's VLM Architecture
 
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full Recording
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full RecordingOpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full Recording
OpenChain AI Study Group - Europe and Asia Recap - 2024-04-11 - Full Recording
 
Patterns for automating API delivery. API conference
Patterns for automating API delivery. API conferencePatterns for automating API delivery. API conference
Patterns for automating API delivery. API conference
 
Powering Real-Time Decisions with Continuous Data Streams
Powering Real-Time Decisions with Continuous Data StreamsPowering Real-Time Decisions with Continuous Data Streams
Powering Real-Time Decisions with Continuous Data Streams
 
Zer0con 2024 final share short version.pdf
Zer0con 2024 final share short version.pdfZer0con 2024 final share short version.pdf
Zer0con 2024 final share short version.pdf
 
SAM Training Session - How to use EXCEL ?
SAM Training Session - How to use EXCEL ?SAM Training Session - How to use EXCEL ?
SAM Training Session - How to use EXCEL ?
 
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...
JavaLand 2024 - Going serverless with Quarkus GraalVM native images and AWS L...
 
eSoftTools IMAP Backup Software and migration tools
eSoftTools IMAP Backup Software and migration toolseSoftTools IMAP Backup Software and migration tools
eSoftTools IMAP Backup Software and migration tools
 
Salesforce Implementation Services PPT By ABSYZ
Salesforce Implementation Services PPT By ABSYZSalesforce Implementation Services PPT By ABSYZ
Salesforce Implementation Services PPT By ABSYZ
 
VictoriaMetrics Q1 Meet Up '24 - Community & News Update
VictoriaMetrics Q1 Meet Up '24 - Community & News UpdateVictoriaMetrics Q1 Meet Up '24 - Community & News Update
VictoriaMetrics Q1 Meet Up '24 - Community & News Update
 
Introduction to Firebase Workshop Slides
Introduction to Firebase Workshop SlidesIntroduction to Firebase Workshop Slides
Introduction to Firebase Workshop Slides
 
Ronisha Informatics Private Limited Catalogue
Ronisha Informatics Private Limited CatalogueRonisha Informatics Private Limited Catalogue
Ronisha Informatics Private Limited Catalogue
 
UI5ers live - Custom Controls wrapping 3rd-party libs.pptx
UI5ers live - Custom Controls wrapping 3rd-party libs.pptxUI5ers live - Custom Controls wrapping 3rd-party libs.pptx
UI5ers live - Custom Controls wrapping 3rd-party libs.pptx
 
Leveraging AI for Mobile App Testing on Real Devices | Applitools + Kobiton
Leveraging AI for Mobile App Testing on Real Devices | Applitools + KobitonLeveraging AI for Mobile App Testing on Real Devices | Applitools + Kobiton
Leveraging AI for Mobile App Testing on Real Devices | Applitools + Kobiton
 
Post Quantum Cryptography – The Impact on Identity
Post Quantum Cryptography – The Impact on IdentityPost Quantum Cryptography – The Impact on Identity
Post Quantum Cryptography – The Impact on Identity
 

20181016 Agile DC 2018 Conf Kanban Case Study for Energy Company

  • 1. 1 Faster Better Cheaper in a highly regulated environment? Craeg Strong CTO, Ariel Partners October 15, 2018 Washington, DC © Copyright Ariel Partners 2018 *sales@arielpartners.com ((646) 467-7394
  • 2. 2 Agenda Context A. Prior Work B. Selected Engagement Details 1. Agile Requirements Decomposition via User Stories 2. Applying the Kanban Method C. Observations and Discoveries 1. Ongoing Challenges 2. Lessons Learned and Takeaways
  • 3. 3 Craeg Strong Software Development since 1988 Large Commercial & Government Projects Agile Coach / DevOps Engineer Kanban Trainer / SpecFlow Trainer Performance & Scalability Architect Certified Ethical Hacker New York & Washington DC Area CTO, Ariel Partners AKT, KMP, CSM, CSP, CSPO, ITILv3, PMI-ACP, PMP, LeSS, SAFe www.arielpartners.com cstrong@arielpartners.com @ckstrong1
  • 5. 5 Unique Challenges for Energy Sector Highly Constrained COTS Product Few Developers With Deep Domain and Product Knowledge Lengthy Analysis Required Customers Often Unavailable Highly Distributed Organization
  • 6. A. PRIOR KANBAN IMPLEMENTATION
  • 7. 7 Initial Kanban Implementation 1. Established LeanKit to track the work 2. Process captured as-is, no changes 3. No changes to existing responsibilities or titles Consultant helped IT teams implement Kanban in early 2017 Before Kanban SharePoint Functional Requirements Document System Design Document Detailed Design Document User & Admin Guides Analyze Design Build Test Deploy With Kanban A) No Changes To Documentation B) Requirements Captured on Cards C) Kanban board lanes reflect process steps Minimum Marketable Feature
  • 8. 8 Minimum Marketable Features Minimum As small as possible. If an MMF can be subdivided into multiple MMFs, it should be– even if those MMFs are to be delivered together. Marketable Something that could be potentially deployed on its own (used in production, with live data) Feature Something that is perceived, of itself, as value by the user. Minimum Marketable Features. The smallest set of functionality that must be realized in order for the customer to perceive value. A “MMF” is characterized by the three attributes: minimum, marketable, and feature.
  • 9. 9 Initial LeanKit Implementation HypercareBacklog Deploy System / User Test Build / Unit Test Func Design Reqs Analysis Approval
  • 10. 10 Development Process Back Office Demand Middle Office Front Office Governance Committee Analysis Committed& SequencedQueue Uncommitted Arrivals Backlog Analysts Developers Testers Hypercare Average 120+ Days (!!!) Approval Gate IT Need to Do Better Analysts Play Both Roles Other
  • 11. 11 Kanban Foundational Principles 1. Start with What you do Now 2. Agree to Pursue Incremental, Evolutionary Change 3. (Initially) Respect the Current Process, Roles, Responsibilities & Titles Hmmm, we got stuck on this one
  • 14. 14 As Is versus To Be As Is Delivered MMF Lengthy Delays Lack of Visible Progress Kanban Board not adding value Difficult to Estimate Difficult to Subdivide Identified Minimum Marketable Feature User Story User Story SpikeSpike  Regular Visible Progress  Kanban Board tells a story  Small, estimable chunks  Independently valuable stories  Can assign work to multiple teams To Be Delivered MMF User Story Idea or Request Identified Minimum Marketable Feature
  • 15. 15 Decomposing MMF into User Stories… MMF User Story Relationship Parent Child Effort 2 weeks to 4 months of development 2 days to 2 weeks Analysis Requirements Document As a/I want/So that Possibly a UX mockup Testing Test Plan (up to dozens of tests) 2-12 Acceptance Criteria Value to Business Immediately recognized as independently valuable Has value to the business, but the value may be best realized when combined with other user stories split out from the MMF
  • 16. 16 …and Spikes User Story Spike Goal Realize business value Reduce risk by answering a question or gathering information Effort 2 days to 2 weeks 2 days to 2 weeks Completion Acceptance Criteria fulfilled Hypothesis is proven true or false Next Steps Testing, Documentation, Deployment Discarded or recycled
  • 17. 17 Properly Formed User Stories Splitting User Stories 1. Performance (ways to add caching or improved performance) 2. Simple to complex 3. Interface variations: excel, grid, graphical, mobile, 4. Variations in data: geographic region, or by refinery, or by customer 5. Operations: splitting out CRUD 6. Business rule variations 7. Workflow steps: this then that 8. Breakout a spike INVEST 1. Independent 2. Negotiable 3. Valuable 4. Estimable 5. Small 6. Testable User Story Components 1. “As a…” Identify the Stakeholder. More than one? Split! 2. “I want…” Identity the function the way the stakeholder would 3. “So that…” Identify the business value. What is the Stakeholder’s goal? 4. Acceptance Criteria 1. Assumptions 2. Invariants 3. Pre- and Post-Conditions
  • 18. 18 Example #1: EBITDA Story Compute Operating Income component of EBITDA by company Story Compute Income Tax component of EBITDA by company Story Compute Depreciation component of EBITDA by company Story Compute Interest component of EBITDA by company Story Compute Amortization component of EBITDA by company Story Compute EBITDA by company combining component calculations Story Control Access to EBITDA calculations by company Story Reconciliation report to compare EBITDA in AO report to BPC P&L statement Story Schedule report to enable reconciliation during close MMF Description EBITDA Calculations by Company – for Accounting and Reporting Team Earnings before interest taxes depreciation and amortization
  • 19. 19 Example #2: Trader Checkout Process Story Basic read-only details view for trader for formula tablet Similar to existing report, but omits trades already approved or rejected, activated or pending. Most trades have formula tablets Story Trader can approve or reject deal details Story Trader can only approve/reject their own trades Story Read-only form for middle office to review rejected details Story Force modified deals to be re-approved Story Update historical deal details so I don’t have to approve them Spike Determine how fixed price tablets will be displayed Small percentage of trades have fixed price tablets Story Support fixed price tablet support for TCM view MMF Description New Trader Checkout Process (TCM) For Audit To prevent booking errors, have traders explicitly approve or reject trades on a daily basis before they are activated
  • 20. B2. APPLYING THE KANBAN METHOD* *STATIK: SYSTEMS THINKING APPROACH TO IMPLEMENTING KANBAN
  • 21. 21 1. Leading Questions 2. Motivations for Change 3. Analyze Sources and Nature of Demand 4. Identify and Define Classes of Service 5. Analyze Delivery Capability 6. Model Delivery Workflow 7. Kanban System Design (Lane Policies, WIP Limits, Replenishment Cycles, etc.) Applying the Kanban Method
  • 22. 22 Motivations For Change Internal Dissatisfaction Work beginning on MMF but card is stuck “waiting for approval” Significant time spent on documentation (Reqs doc, Func spec, Tech spec) Not much day-by-day movement on the board Large projects do not appear on the board No visibility Into Work Being done for MMF Difficult to tell what is blocked or high priority Coordination with Other Groups (e.g. Help Desk) not reflected on board How Can I tell what has moved since last week? External Dissatisfaction Too slow / Long lead time Unpredictable delivery Quality issues
  • 23. 23 Updated LeanKit Board Design Backlog Approval Reqs Analysis Func Design Build / Unit Test System / User Test Deploy Hypercare Previous Flow Hypercare DefectsUser Stories & Spikes Backlog On Deck Reqs Analysis Design / Build System Test User Test Deploy Hypercare Specify Ready In Progress Func Test Identify In Progress Test Deploy Updated Flow
  • 24. © Copyright Ariel Partners 2018 *sales@arielpartners.com ((646) 467-7394 24 Updated Board
  • 25. 25 On Deck Lanes: Two MMFs Per Stakeholder Group All Five Stakeholder Groups Can Indicate their Top Two Priorities Top Two Can Change Anytime Prior To Commitment
  • 26. 26 Parallel Parent[MMF] and Child[User Story] Work Child Stories Created When MMF Analysis Begins “Ready” User Stories Can Be Completed Anytime Additional User Stories Created As Needed During MMF Analysis & Design Spikes Created As Needed Finish-to-Finish Dependency (MMF to Child Story)
  • 27. 27 Hypercare Defects Captured External Defects Appear Directly Under Their Parent MMF Separate Card Type (Hypercare vs Internal Defect) Makes Querying Easy
  • 28. 28 Improving Functional / Technical Team Collaboration Functional Team Technical team Handoff From This… Time Level Of Effort MMF Reqs Analysis MMF Design & Build … To This! Functional Technical Level Of Effort Time Story Identification Story In Progress MMF Design MMF Reqs Analysis Explicit Entry/Exit Policies Explicit Entry/Exit Policies Explicit Entry/Exit Policies
  • 29. C. ONGOING CHALLENGES & LESSONS LEARNED
  • 30. 30 Lessons Learned for Highly Regulated / COTS / Energy Challenge Response 1. Spikes frequently needed to explore different designs 2. Estimation process helps team identify areas of significant uncertainty and risk (Extra-Large “T” Shirt) Older Development Platform, Largely Manual Processes Development takes longer; user stories must be split more fine-grained Highly Specialized Team Members Not Fungible Benefits from “swarming” and collaboration are limited, often leading to increased Work In Progress Stakeholders Unavailable for Extended Periods of Time Identify backup stakeholders & More Up-Front Estimation and Planning Required to avoid Blackout times Highly Complex Commercial Software Package
  • 31. 31 Takeaways Kanban Well-Suited for “Highly Constrained” SW Development Low Barrier to Entry Transparency Promotes Trust Highlights Sources of Delay Conducive to Incremental Change Compatible with SDLC methods (Waterfall, Scrum, SAFe, etc.) Kanban Method and STATIK Simple and Powerful Techniques Helps Break down Barriers and Encourage Collaboration Limiting the amount of Work in Process reduces Overburdening Improvement Workshops can be repeated as needed
  • 32. 32 Discussions, Q & A © Copyright Ariel Partners 2018 *sales@arielpartners.com ((646) 467-7394 Craeg Strong Savant Financial Technologies, Inc. d/b/a Ariel Partners Cell: (917) 992-0259 cstrong@arielpartners.com www.arielpartners.com @arielpartners Thank You!

Notas del editor

  1. Good afternoon! My name is Craeg Strong and today I will be talking about using Kanban for software development in the energy sector, which is a highly regulated and complex environment. You may be asking yourself how Kanban could be used for software development– isn’t it just for infrastructure support? What I hope to show you is that not only is it great for software development, it is particularly helpful in highly constrained environments with complex domains and significant compliance and regulatory issues.
  2. I will start out providing some context Then I will describe the situation when we arrived based on some prior work that was done. I will go into just a few of the improvements we made along the way And finish up by describing our lessons learned and where we will go from here
  3. I am a software developer and devops engineer, but more importantly I am a certified Kanban trainer and I coach teams on test automation and agile methods My company is in NY and DC, and we work for a variety of commercial and government customers
  4. the logistics of extracting, storing, transporting, and trading petroleum products are very complex Energy trades involve multiple components and counterparties and millions of dollars Our business stakeholders that we get our requirements from are typically located at the refineries. The only problem is that refineries get partially or completely shutdown on a regular basis in order to implement improvements, or for regulatory or compliance reasons. During those periods, called turnarounds, it is basically impossible to get requirements or feedback from our customers Of course, you try plan around that, but sometimes there is very little advanced warning.
  5. There are a small number of big complex commercial software packages that are used by basically everyone in the energy sector. Because they are so complex, and the domain itself is so hard to grasp, there are just not going to be that many people on the team that are masters of both This means that complex analysis is required, and many questions need to be asked– but remember that our customers may disappear without warning due to a turnaround. To make matters worse, the refineries are scattered all over the US, and the company has offices worldwide.
  6. Now that we set the stage, I’ll describe the situation as we found it when we started back in May of this year.
  7. A consultant had set up an initial kanban board for the company back in early 2017, using the LeanKit software tool The intent was to capture the existing process exactly as it was, with no changes. Historically, the work was captured in a set of documents stored in sharepoint. Those documents probably look familiar to many of you– functional requirements document, design documents For the new process, the documents were maintained exactly the same way. The only new concept that was introduced was the minimum marketable feature or MMF I’ll describe what an MMF is in a moment. By representing each requirement as an MMF card, they were able to capture all of the in-flight requirements together on a kanban board.
  8. So what exactly is an MMF? well it has three components First– it is as small as possible– which means if it could be subdivided, it would be. Second, it is marketable, which means it can be deployed on its own and used in production Third, it is something that is directly perceived by the business as valuable
  9. So here is the original implementation in leankit. Because the lanes are hard to read, I copied them down below So.. Taking a look at those, can anyone tell me what SDLC process that resembles? Let me give you a hint. Yes, this is waterfall! We are using a kanban board to represent an unchanged waterfall process. The one benefit we really have here is visibility.
  10. Here is how it all worked. We had five different stakeholder groups. Those were the sources of our demand. Requirements coming from them are approved by a governance committee, and then go into the team’s backlog. When an item is removed from the backlog and worked, it starts out with the analysts, then its handed to the developers, then testers, and finally gets to hypercare. Hypercare is a two to four week period where the item is in production, but support has not yet been handed off to the operations team. Sounds good, so what is the problem here? It is cycle time! It takes the team an average of more than 4 months to get an item from backlog to hypercare.
  11. So how can Kanban help? Let’s look at the kanban foundational principles. We definitely started with what we do now. We absolutely respected the current process, roles, responsibilities, and titles, but we seem to be missing something. We got stuck and did not make any changes!
  12. So that is what we set out to do. Since then we have made a number of incremental improvements, and I’d like to highlight two of them
  13. First, I provided coaching regarding how to decompose requirements
  14. So why do we need to decompose requirements? Why aren’t the MMFs good enough? The problem is that most of them were quite large. Because of this, they would sit in a lane for weeks or months. Day by day, the board rarely changed, which unfortunately lead to most people simply ignoring it. The analysts would ask the developers for estimates, which sometimes could be off by an order of magnitude or more. After it was analyzed, the MMF would basically go into a black hole and would not be heard from for weeks or months until it was somehow delivered. So I introduced the concept of user stories. There is nothing magic about user stories, and they are not mandated by kanban nor scrum. However, they are a well-known and well documented technique, so why reinvent the wheel. Not only user stories but also spikes. So how do MMFs, user stories, and spikes relate to each other?
  15. The answer is pretty simple. The MMF would be decomposed into one or more child user stories. We followed a very standard definition of user stories and expected them to take between two days and two weeks. Although each user story provides value, we would still wait until all child user stories were completed before delivering the MMF to the business. The team asked– what if we don’t have all the information we need to create a user story up front? How can we move forward? So we also introduced the notion of a spike, popularized from Extreme Programming back in 1999.
  16. We defined a spike as some work you perform to reduce risk by answering a question or gathering information. So– for example if a solution could take two weeks or two months depending on whether a suitable API already exists or not, that question needs to be answered. A spike could be done by an analyst or a developer, or both working together. It could involve in depth analysis of a business problem, or looking at the commercial software or some other tool or technique. So as soon as we have our answer, we document it as the outcome of our spike and move forward. In any event a spike is time boxed to take no longer than two weeks.
  17. Now that we had our taxonomy, it was time to learn how to write user stories. We structured them in the standard way, and learned about characteristics of a good user story. However, by far the biggest challenge was splitting them to make them very fine grained. There is a wonderful online resource at the agileForAll website that illustrates a bunch of ways to split a story, and I listed some of them here. So the teams stopped me at this point and said– this is all well and good, but that stuff just won’t work here. We can’t possibly split our MMFs to be any finer grained. That only works for those web designers. The subject matter is too complex, and the commercial software package we are using just doesn’t lend itself to building something up piece by piece. So there is a fake Mark Twain quote that goes like this: “it aint what you know that gets you into trouble. It is what you know for sure that just ain’t so.” Let me illustrate with two quick examples
  18. Let’s take EBITDA: earnings before interest taxes depreciation and amortization. Is there anything there that suggests splitting? Indeed. When we have a calculation that involves sub-calculations, we can split each of those out into separate stories. No sweat!
  19. For another example, we have the trader checkout process. It turns out that traders were not double-checking all the details for their trades, which lead to some incorrect or incomplete trades needing to get backed out. Yikes! So we need to introduce a double check process where traders can review the details and approve or reject them individually. First of all, it turns out that trades are priced out in two different ways: fixed price and via formulas. Formulas were easy and they represent 90% of all trades. Aha- let’s do those first! After that it is a matter of breaking down the business process into steps, and implementing them one at a time. First we have the ability to approve or reject, then restrict that to only my own trades. Question– what happens if a detail gets rejected? The middle office needs to review it and decide what to do. Voila, another user story. And so on.
  20. We also applied the kanban method via STATIK STATIK is the systems thinking approach to implementing kanban. It provides a simple recipe of useful techniques that can be applied to any workflow process to improve it.
  21. There are 6 or 7 basic steps, depending on how you count them. We start out understanding the sources of dissatisfaction- you have to understand the problem first! We analyze where our demand comes from, and what it looks like. When do our requirements need to be expedited? Which ones have a fixed deadline, like April 15 for taxes? We call those different classes of service. Then We need to understand our delivery capability Then we can model our workflow. Rather than just looking at development we want to look all the way from early conception thru operations where the value is really felt– or not. Lastly we can apply policies, limit our work in progress, and decide how often to replenish our backlog.
  22. Most of the motivations for change I have already described. However, we found that many activities were not reflected on the board at all. Also we found that significant time was spent waiting for approvals for documents. All of this lead to long cycle times, often lasting more than 4 months.
  23. I will skip ahead to the workflow design. Here is the previous flow. We wanted to make some relatively modest changes that would yield some big benefits. First of all, we eliminated the approval step. We realized that the MMFs were already approved by governance by the time we got them. The documents didn’t really need to be “re-approved” but merely accepted. Most of the time, as long as the document was accepted before the MMF went to production we were fine. No need to wait! Secondly, we introduced a parallel flow for user stories and spikes, so we could work on those while the MMF was being analyzed. Lastly, we observed that defects that occur while an MMF is in hypercare get a very different workflow than the ones that happen in development. We want to make sure we make production defects highly visible– and how better to do that than to put them right next to the MMF hypercare lanes. I will first show you the overall board, and then go into each of these in a little more detail.
  24. Here is the updated board– you can see an “On Deck” section here, and a parallel swim lane for user stories and spikes.
  25. We wanted to make it easy for the team to grab the next most important card. Front office, middle office, back-office, Technical, and Other Groups. So each stakeholder group gets an “On Deck” area where they can put their two highest priority cards. Notice how the lane is exactly two cards wide.
  26. We created a parallel swim lane where user stories and spikes would be worked on. The team explained that MMFs could take a long time to analyze and design-– but that there were usually some aspects that were fairly well understood up front. So by creating a parallel structure, we enabled the team to ”peel off” spikes and stories as soon as they were understood. The MMF was finished as soon as the analysts were done, and all the user stories were completed-- a finish-to-finish dependency. This way maximizes the ability to work in parallel– and makes it clear visually that work is truly happening on BOTH the parent and child cards at the same time.
  27. At the right hand side of the board, we have hypercare– when the MMF makes its way to production but prior to handoff to the operations team. We put a parallel swim lane just for production defects right under the hypercare lanes, so it is immediately obvious when a hypercare MMF has a bug. If it’s a high priority bug, the MMF will get a big red stop sign meaning it is blocked, while the defect is worked on and makes its way through change control.
  28. We knew we needed to improve team collaboration. Previously, the functional team would work on their requirements and then just lob them over to the technical team to implement. By creating this parallel structure, we encouraged the developers and analysts to work together continuously, while recognizing that the analysts may have a bit more work to do at the beginning, and the developers may have a bit more work to do at the end. We encouraged this visually via the parallel swimlanes, but also by having the team craft explicit entry and exit policies that describe the responsibilities of each team for each step of the way. How many of you are familiar with Scrum Definition of Done, and definition of ready? They are basically entry and exit policies for work in the system. Kanban takes that concept and generalizes it– so we capture policies for every single step in the workflow. All team members can review the policies at any time right from the tool. It’s a powerful way to encourage good collaboration.
  29. Based on the experience of exploring and deepening kanban at this company, there are some interesting lessons learned
  30. What is different about using agile methods on a project where you have a complex commercial software package? A couple of things. We tend to see more spikes. Also even though estimates are not normally part of kanban, the team estimates T shirt sizes for user stories– primarily to make sure they are granular enough. The SW platform is older and there are a lot of manual proceses. This means development takes longer. What would take 2 days for a modern web application could take 2 weeks. This means we have to really split our user stories fine grained to get a good level of throughput. With such a complex business domain, many of team members are specialists in a very specific area. The result is we have to constantly guard against increase in work in progress– people are tempted to take on new work rather than help others finish their work because “that is not my area.” Our stakeholders that just gave us a high priority requirement may be in a turnaround and might suddenly not be available. Although we try to get backups, this also means we need to plan more in advance to help avoid these blackout times.
  31. So what are some key takeaways? First– kanban is well suited for highly constrained software development – legacy-heavy development, or with burdensome compliance and governance processes. Easy to get started High degree of transparency Conducive to implemental change And you can start with waterfall, scrum SAFe or whatever. The kanban method gives you a set of simple and powerful techniques that help break down cultural barriers and encourage collaboration, reducing the amount of work in process to relieve overburdening. And you can repeat these improvement workshops as needed We are enjoying our time working with the energy company and are looking forward to finding new ways to improve.
  32. Thank you very much! I think we have about 15 minutes for questions.