Vou tentar dar uma pequena contribuição para esta discussão ... ;-)
- Scrum é um método de gerenciamento de projetos;
- Tipicamente, de projetos de desenvolvimento de produto (Product Backlog);
- Scrum tem como foco principal a entrega de valor para o cliente (Product Owner);
- Para tanto, explora a auto-gestão da equipe (Scrum Team);
- A equipe deve manter altos níveis de comunicação e colaboração;
- Scrum é baseado em muitos princípios e práticas do Lean Thinking;
- Por essa razão, exige um fluxo de valor do tipo Just-in-Time (JIT);
- Por ser JIT, trabalha com pequenos intervalos de produção (Sprints);
- Devido a isso, faz entregas frequentes com estoques reduzidos;
- Por ter estoques reduzidos, traz os problemas à tona;
- Uma vez que problemas podem surgir, um líder deve procurar contorná-los (Scrum Master);
- Os problemas são discutidos diariamente com a equipe (Daily Scrum);
- Bem como a evolução do produto (Burndown Chart);
- O produto evolui de forma dinâmica, de acordo com os interesses do cliente (Sprint Backlog);
- E equipe se compromete com os resultados do projeto (Sprint Planning);
- Os resultados obtidos são avaliados durante as entregas parciais do produto (Sprint Review);
- E uma análise crítica dos resultados é feita após cada entrega (Restrospective);
- E todo o processo reinicia até chegarmos ao produto desejado.
Por que eu escrevi esses 18 pressupostos? Porque muitos deles são diretrizes para o planejamento do meu processo de desenvolvimento. O Scrum não é um método prescritivo ao extremo, como é o RUP, que entrega até os templates de como você deve escrever cada artefato. Tanto um quanto o outro eu posso considerar como frameworks de processo, dado que a instância de cada um será diferente em cada empresa onde eles forem implantados. No entanto, tanto um quanto outro não abrem mão de suas diretrizes "obrigatórias", como no caso do Scrum com: Sprint de prazo fixo (2 a 4 semanas), um único Product Backlog (que muita gente ainda desconhece o poder de uma User Story), Daily Meeting (que muita gente não faz), Sprint Planning e Review (que muita gente não sabe como conduzir), Retrospectives (que muita gente não tem no sangue a melhoria contínua), Burndown Chart (que muita gente ainda tem alergia a métricas e indicadores de desempenho). Nestes itens, não há flexibilidade. A flexibilidade que existe é na exploração do processo criativo para o desenvolvimento do melhor produto, no melhor tempo e no melhor custo, a fim de atender as necessidades de meu cliente.
Ou seja, da mesma forma que um framework MVC tem dentre suas diretrizes obrigatórias a construção das classes GUI na estrutura V do modelo (se você colocar no M vai deturpar o modelo e prejudicar a manutenção e o controle do sistema), o Scrum possui essas características. Se seu sistema foi desenvolvido com base nesse framwork (MVC), mantendo total aderência às suas diretrizes obrigatórias, pode-se dizer que o sistema é uma instância do modelo MVC. Se seu processo de desenvolvimento de software foi planejado com base no framework Scrum, mantendo total aderências às diretrizes obrigatórias, pode-se dizer que o processo é uma instância do modelo Scrum. Conclusão: o Scrum é um framework!
4 comentários:
muito bacana o texto... vou entrar na lista scrum-brasil para acompanhar mais...
Parzianello, muito interessante o teu post. Tomei nota dos 18 pontos citados pela tua metodologia. :)
Abraço
Conteudo bem interessante ...
Parabens pela clareza
Ótimo conteúdo.
Precisamos ligar mais o Scrum ao Lean nas discussões e fóruns e expandir a utilização tanto do Scrum quanto de outras ferramentas Lean (Hoshin Plan, VSM, etc) para outros processos das Organizações.
Quero participar dessa empreitada.
Postar um comentário