Na tento vzorec jsem nedávno narazil v knížce Lead with Respect. I když je to takový překladatelský oříšek, v originále job = work + kaizen, tak myšlenka za ním je jednoduchá. Naše práce se skládá ze dvou stejně důležitých částí. Jednou je plnění úkolů, samotná pracovní činnost, to za co nás platí. U programátorů je to programování. To je jasné. Na co se ale často zapomíná, je druhá část, neustálé zlepšování se – kaizen. To by také mělo být nedílnou součástí pracovního dne. Důvod je jednoduchý. Věci mají tendenci se samy od sebe zhoršovat. Náš skvělý kód se nějakým zázračným způsobem přes noc zkazí. Technologie se posouvají vpřed. Lidi zapomínají. Co včera platilo, dneska už neplatí. Co včera fungovalo, dneska už nefunguje. Proti těmto tendencím musíme vědomě, systematicky, dennodenně bojovat.
I když ten vzorec platí stejně dobře pro jednotlivce jako pro celé firmy, chtěl bych se zamyslet nad tím, co to znamená pro scrumový tým.
Co jsou úkoly je jasné. To jsou věci z backlogu, věci, které po týmu někdo chce. Kde je ale ten kaizen? Je to ta retrospektiva jednou za čtrnáct dnů? Těžko. Smutnou pravdou je, že kaizen v mnoha týmech chybí. Není se čemu divit, ono je to takové nehmatatelné a těžko popsatelné. Vždyť na to ani nemáme pořádné slovo. Je ohromě snadné sklouznout do stavu, kdy tým jenom plní úkoly, které mu přichazí z backlogu. Vždyť to je důvod, proč ten tým vůbec existuje.
Takže se nemůžeme divit, když si někdo myslí, že by úplně všechna práce měla být v backlogu. Včetně refaktoringu, vylepšování infrastruktry nebo zlepšování testů.
Mě připadá, že je to lepší dělat jinak. Je mnohem jednoduší zařídit, aby měl tým na kaizen čas. Dá se snížit zátěž (velocity) týmu tak, aby měl ve většině sprintů časovou rezervu a tím pádem čas na kaizen. Co si ve zbylém čase bude tým dělat, je jen na něm. Může refaktorovat, zlepšovat automatizaci, něco si zkoušet, učit se. Je to oddělená část rovnice, product owner rozhoduje o úkolech, o kaizenu si rozhoduje tým sám. Proč? Protože tým nejlíp ví, kde ho tlačí bota. Je to samoorganizující se tým, proč by mu měl někdo kecat do toho, jak se má zlepšovat?
Snížení zátěže týmu je ta jednodušší část. Ta těžší část je naučit se to zlepšování samotné. Většina lidí to jednoduše neumí (mě nevyjímaje). U refaktoringu je to jednoduché, z ošklivého kódu udělám hezčí. Co ale takové to zlepšovaní procesu, toho jak fungujeme jako tým, ten původní význam slova kaizen? To jsme nikdy nedělali, nikdo nás to nikdy neučil a ošklivě v tom tápeme. Plnění úkolů je mnohem jednodušší a uspokojivější. Proto si musíme neustále připomínat, že práce = úkoly + kaizen.