Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Backlog Refinement #18

Open
PaweuB opened this issue Sep 5, 2018 · 0 comments
Open

Backlog Refinement #18

PaweuB opened this issue Sep 5, 2018 · 0 comments

Comments

@PaweuB
Copy link

PaweuB commented Sep 5, 2018

Backlog Refinement - sesja doskonalenia Backlogu.

PART I

Opierając się o wiele źródeł, można stwierdzić, że Backlog Refinement to jedno z najważniejszych spotkań w SCRUMie. Jednak nie wszystkie źródła traktują to spotkanie w identyczny sposób. Część opisuje to spotkanie jako moment, w którym możliwe jest dopracowanie User Stories w przypadku gdy występuje dużo placeholdersów lub niepewności. Inne źródła mówią o tym procesie jak o narzędziu, które pozwala na utrzymanie Backlogu aktualnego (np. zmiana priorytetów). Jednak większość źródeł jest zgodna: to spotkanie jest często częściowo ignorowane lub występuje w nieregularnych odstępach czasu, prowadzone bez odpowiedniej agendy i przygotowania. Podsumowując - nie ma ono w takiej formie jakiegokolwiek sensu, zabiera czas.

Jednak gdyby się zastanowić nad tym co może dostarczyć dobrze przeprowadzony Backlog Refinement w trakcie Sprintu, okazuje się, że niesie to ze sobą korzyści zarówno dla Produktu jak i Zespołu Developerskiego.

Korzyści:

  1. Ogólne:
  • uporządkowany backlog - opisany (specyfikacja), oszacowany, spriorytetyzowany
  1. Dla Produktu:
  • lepsza priorytetyzacja zadań
  • możliwość poznania zależności między zadaniami o ile takie występują
  1. Dla Zespołu Developerskiego:
  • poznanie sensu biznesowego danych Stories

---

PART II

Czym grozi brak refinementu (błędne koło backlog refinementu):

  • brak uszczegółowienia zadań
  • brak realizacji celu sprintu (odejście od realizacji celu sprintu na rzecz zadań, które mogły „wskoczyć”, nie koniecznie z dobrze dobranym priorytetem)
  • co raz dłuższe rozmowy na retrospekcji (bo przecież chcemy robić lepiej/inaczej)
  • POCZUCIE PEŁNEJ MOBILIZACJI - żeby udało się dowieźć cel sprintu… nie trzeba czuć mobilizacji do działania, wystarczy wiedzieć co się robi.
  • CHĘĆ DZIAŁANIA - po pełnej mobilizacji do działania oraz poświęceniu czasu na „wgryzanie się” w pracę nie ma już czasu na dodatkowe spotkania (np. Refinement) oraz na zastanowienie się nad tym czy aby napewno nasz produkt dąży w dobrym kierunku.

W tym miejscu chciałbym zakończyć bardzo krótkie wprowadzenie w Backlog Refinement oraz w dalszej części dostosować „dojście” do refinementu w trakcie sprintu do realiów Code-Poets.

---

PART III

Biorąc pod uwagę aktualny workflow Code-Poets oraz SCRUMowe podejście do zarządzania projektami przy wytwarzaniu oprogramowania można w odniesieniu do wielu źródeł zaproponować poniższą ścieżkę dojścia do Backlog Refinementu.

Ogólny zbiór wymagań Produktu > Priorytetyzacja wymagań Produktu > Uszczegółowienie Backloga (Stories, Placeholders) > Sprint Planning > Sprint Execution > Backlog Refinement

Jak robić Backlog Refinement?

  1. Kiedy?
    W trakcie sprintu, w ściśle określony dzień, o stałej godzinie.

  2. Jak długo?
    Backlog Refinement powinien zabierać nie więcej jak 10% czasu trwania Sprintu.

  3. Kto?
    W różnych źródłach proponowane są różne konfiguracje personalne do przeprowadzenia refinementu, np. praca w parach senior - junior dev, product owner - senior dev, product owner - architekt.

  4. Jak?
    Tak aby Backlog był uporządkowany i spriorytetyzowany, tak aby spełnić cel sprintu

---

Code-Poets Workflow:
Powyższy opis jest zbiorem informacji pozyskanych z różnych źródeł internetowych. Aby w pełni móc korzystać ze wszystkich dobrodziejstw tego procesu, należy go dostosować do danej organizacji, specyfiki projektu/produktu.
W Code-Poets pomimo niezachowania zasady „organizowania” tego spotkania w wyznaczonym czasie, odbywa się to w sposób ciągły, tj. Continuous Backlog Refinement. Jest to bieżąca/codzienna praca nad Backlogiem. Jest to dobre podejście w projektach, które nie są w pełni wyspecyfikowane na etapie planowania lub bądź nastawione są na szybki rozwój produktu (np. Concent)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants