Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
Artur Hebda "Code is not important...or is it?"
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
Railsware
June 03, 2018
Technology
160
0
Share
Artur Hebda "Code is not important...or is it?"
Artur's presentation at RubyC-2018
Railsware
June 03, 2018
More Decks by Railsware
See All by Railsware
Калыс Осмонов: "B-Tree vs. LSM-Tree: какую систему БД использовать для следующего проекта"
railsware
0
520
Sergii Boiko: "Runtime Model of Ruby, JavaScript, Erlang, and Other Popular Languages"
railsware
0
210
Outsourcing - is a Dead End. Strategic steps on how to evolve your business model.
railsware
1
870
Artur Hebda: Product Engineer - a perfect technical executor for cross-functional teams
railsware
0
450
"How to structure your input so it becomes a manageable scope?" - workshop by Artur Hebda
railsware
0
980
How to Extract Tabular Data from Scanned PDF's?
railsware
0
5k
Runtime Model of Ruby, JavaScript, Erlang, and other popular languages
railsware
0
190
BDD style testing for Swift with Sleipnir
railsware
2
280
Building up the product: who you need and when
railsware
0
660
Other Decks in Technology
See All in Technology
巨大プラットフォームを進化させる「第3のROI」
recruitengineers
PRO
2
1.2k
Choose your own adventure in agentic design patterns
glaforge
0
150
20260428_Product Management Summit_tadokoroyoshiro
tadokoro_yoshiro
14
14k
UIライブラリに依存しすぎないReact Native設計を目指して
grandbig
0
140
ネットワーク運用を楽にするAWS DevOps Agent活用法!! / 20260421 Masaki Okuda
shift_evolve
PRO
2
220
Shipping AI Agents — Lessons from Production
vvatanabe
0
280
Microsoft 365 / Microsoft 365 Copilot : 自分の状態を確認する「ラベル」について
taichinakamura
0
350
AIが書いたコードを信じられない問題 〜レビュー負荷を下げるために変えたこと〜 / The AI Code Trust Gap: Reducing the Review Burden
bitkey
PRO
8
1.4k
AIでAIをテストする - 音声AIエージェントの品質保証戦略
morix1500
1
140
AndroidアプリとCopilot Studioの統合
nakasho
0
130
AIコーディング時代における、ソフトウェアサプライチェーン攻撃に対する防衛術(簡易版)
soysoysoyb
0
120
国内外の生成AIセキュリティの最新動向 & AIガードレール製品「chakoshi」のご紹介 / Latest Trends in Generative AI Security (Domestic & International) & Introduction to AI Guardrail Product "chakoshi"
nttcom
4
1.4k
Featured
See All Featured
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
380
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Fashionably flexible responsive web design (full day workshop)
malarkey
408
66k
A Tale of Four Properties
chriscoyier
163
24k
I Don’t Have Time: Getting Over the Fear to Launch Your Podcast
jcasabona
34
2.7k
SEO in 2025: How to Prepare for the Future of Search
ipullrank
3
3.4k
実際に使うSQLの書き方 徹底解説 / pgcon21j-tutorial
soudai
PRO
199
73k
Digital Projects Gone Horribly Wrong (And the UX Pros Who Still Save the Day) - Dean Schuster
uxyall
0
1.2k
世界の人気アプリ100個を分析して見えたペイウォール設計の心得
akihiro_kokubo
PRO
69
39k
How to Grow Your eCommerce with AI & Automation
katarinadahlin
PRO
1
170
Distributed Sagas: A Protocol for Coordinating Microservices
caitiem20
333
22k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Transcript
Code is not important… Artur Hebda Railsware Labs or is
it?
Context of code Product story Building vision Growing structure Pro
t-d i n me k }
We’re not hired to just write code.
Image: https://www.washingtontimes.com Not available for 6 hours +6500 calls discarded
11 mln people affected Reason : counter overflow 911 outage in USA
“Software engineers don’t understand the problem they’re trying to solve,
and don’t care to. Nancy Leveson, Software-safety expert, MIT
Code always exists within a product context.
Customers pay for the value product delivers to them.
“It’s great to rewrite your code and make it cleaner
and by the third time it’ll actually be pretty. But that’s not the point. Joel Spolsky
We’re hired to build & ship products.
Context of code Product story Building vision Growing structure Pro
t-d i n me k }
Motivation behind OrgMap What is going on?
Q : How it?
Q : How il s i on ?
Q : How su e?
Q : Wha t e t p e? +
+ + +
Seems strange… right? We used existing services / hack our
way through We leveraged product development through experiments We closed feature loops ... And eventually built our own product
“I don't know how to do this, so let's do
it the simplest way and we'll figure out.
Image: http://www.freeimages.co.uk Experiment to build something people want.
We have $50k of tech debt We embraced it to
learn a lot through experiments over the years Image: http://xarxanet.org
Context of code Product story Building vision Growing structure Pro
t-d i n me k }
Building vision constantly
Image: http://www.orlandospencer.com Product is a never consistent set of features
Split product into feature components
Have as much vision as you can Gather product group
Short-term / mid-term / long-term Based on current knowledge For each component
Short-term http://www.donsmaps.com/images29/middleearthlarg elargerstill.jpg Image: http://www.donsmaps.com
Make educated guess I think it would be good to
do...
Validate hypothesis with experiments A C B D
Natural tendency to predict further direction A C B D
E?
Refine vision A C B D Wrong Correct
A C B D Wrong Correct inflexibility Refine vision
Mid-term http://www.donsmaps.com/images29/middleearthlarg elargerstill.jpg Image: http://www.donsmaps.com
Customers ask for a feature I really need that.
“If I had asked people what they wanted, they would
have said: faster horses... Henry Ford
Q : Res t u s em t ?
Combined features
Demo - measure what is changing I like it, but
maybe if…
Long-term http://www.donsmaps.com/images29/middleearthlarg elargerstill.jpg Image: http://www.donsmaps.com
Actual customer validated stuff Usage ~ long-term
Context of code Product story Building vision Growing structure Pro
t-d i n me k }
Grow supporting structure Image: https://www.autodesk.com
“Good code (...) provides highest value for the lowest cost.
99 Bottles of OOP by Sandi Metz and Katrina Owen
Assess tech compliance to vision Gather tech leadership group Look
at architecture for each feature component See how it complies / supports vision
Increase code quality and structure rigidity as you head towards
long-term
Build experimental structure for short-term vision Get answers Acquire knowledge
Image: http://freeimages.com
Improve structure for mid-term vision Clean up after experiments Reflect
acquired knowledge Image: https://www.bonsaiempire.com
Build rigid structure for long-term vision Image: https://www.maxpixel.net Stabilize and
scale
Maintain reasonable code quality for everything Low quality will slow
you down Code without tests is harder to refactor Automate code quality assessment Automate processes - CI & CD
99 Bottles of OOP by S. Metz & K. Owen
https://www.sandimetz.com/99bottles/
Practice thorough PR reviews Do self-review before asking someone else
Assess what cannot be automated yet Review like you would have to continue working on that right away
Reduce tech debt for the vision one step at a
time
What is tech debt? Not only TODO and FIXME Rem
r i l il ?
Make tech debt transparent Image: http://stocksmasters.com
Prioritise tech debt 5.times { why? }
Handle tech debt from backlog
“Make the change easy (warning: this may be hard), then
make the easy change. Kent Beck
Boy Scout Rule - now or later?
Do not refactor without vision
“You should not reach for abstractions (...) resist them until
they absolutely insist upon being created. 99 Bottles of OOP by Sandi Metz and Katrina Owen
Give yourself enough flexibility
Have strategic discussions Rails? React?
Summary Code exists in a product context, hence supports it
Use product vision as a guidance for code Prefer understandability and let abstractions emerge Address inflexibility where it matters
One more thing...
So… is code important or not?
So… is code important or not? As important as value
it creates.
Thank you! Questions? Follow @railsware
Thank you! Questions? Follow @railsware
Thank you! Questions? Follow @railsware