Como foi a meetup Mob Programming Workshop?

O que é Mob Programming?

Mob Programming é uma abordagem de trabalho em time, incluindo não apenas pessoas que desenvolvem código, mas também todos que fazem parte da criação do produto como designers, testadores, ScrumMasters, Product Owners. Tanto pessoas técnicas e quanto pessoas de negócio.

Imagine todo o time trabalhando na mesma coisa, ao mesmo tempo, no mesmo espaço, e no mesmo computador. É uma técnica de trabalho realmente em time, que além de gerar uma solução de alta qualidade, o compartilhamento de conhecimento é constante.

A meetup de Mob Programming

Dia 31/01 nos encontramos em Porto Alegre pela Meetup Agile Open Space, no espaço gentilmente cedido pela DBC Company. Por 2 horas discutimos Mob Programming e obviamente codificamos. Inclusive pessoas que nunca programaram na vida, nem em cursos.

Apresentei um problema real a eles, que realmente os engajassem. O problema era que eu sortearia uma inscrição para o workshop de um dia todo, que acontecerá dia 09/02.

Tínhamos 13 pessoas, incluindo eu, o facilitador que também iria programar. Pedi a todos organizarem suas cadeiras em forma de U em volta do telão, para que todos pudessem olhar os outros e também ficarem confortáveis ao olhar para o código projetado na TV.

Isso já faz com que as pessoas se movimentem, e ajudem no próprio espaço do workshop, um dos primeiros passos para engajarem as pessoas. Essa é uma dica de facilitação: todos ajudam e todos colaboram. Pessoas são serem sociais naturalmente, e quando ajudam o próprio grupo se sentem engajadas por um propósito. Fiz isso parecido no TDC 2018 em Poa, na trilha de XP. Evoluir o design físico pedido ajuda e feedback rápido dos participantes.

Pessoas que não codificam ou não sabem codificar participando do Mob Programming como drivers?

Questionei os participantes e descobri que haviam duas pessoas que nunca programaram, além da maioria não conhecer ou dominar Java, a linguagem que utilizamos no workshop. Isso era uma preocupação dessas pessoas, então questionei também se eles queriam participar voluntariamente como driver (quem codifica no teclado), além de serem navegadores (que guiam o driver). O legal é que todos se voluntariaram a serem drives, inclusive quem não sabia codificar!

Isso é realmente impressionante!

Fiquei bastante contente com isso, e com uma atenção em especial ao grupo todo para fluir bem na criação de um ambiente seguro, porque todos ali iriam expor suas habilidades, ou a ausência delas. A busca por ambiente seguro é absolutamente essencial em Mob Programming. Tanto que os valores de Mob Programming são Gentileza (Kindness), Consideração e Respeito. Por isso também que retrospectivas diárias são importantes em Mob Programming. Sim, diariamente. Pode ser no final ou no início do dia, como o time decidir. Ah, e não há reuniões diárias tradicionais, porque todos já trabalham juntos e a comunicação é a todo momento.

A rotação era de 3 minutos, com 13 pessoas, fecharia um ciclo de todos participarem e ainda teríamos tempo para uma retrospectiva de fechamento. Perfeitamente após o ciclo, completamos a solução com Test-Driven Development (TDD). Criamos dois testes em JUnit bastante significativos. Ok, não tivemos tempo para melhorar o código com refatoração, isso é algo que sabemos que faltou tempo, e que faríamos com certeza se houvesse um próximo ciclo de Mob Programming. Isso ficou na consciência do time, a importância de clean code. O código está no GitHub em https://github.com/dsmoura/mob-programming-workshop-pocket

A rotação do driver acontece num período maior de 3 minutos num time já utilizando Mob Programming há um bom tempo, normalmente entre 7 e 10 minutos. O tempo de rotação em 3 minutos é para tornar a melhoria contínua do processo mais rápida. Por isso uma retrospectiva a cada ciclo inicial de Mob Programming.

O time precisa usar Mob Programming o tempo todo?

Não. Mob Programming é uma forma de trabalho que o time precisa aprender e decidir quando melhor utilizá-la. Dentro da cultura da organização, se o time quiser utilizar Mob Programming o tempo todo, tendo antes experimentado e mostrado que a qualidade da solução é aprimorada e a produtividade está boa, quem sabe até excelente, por que não?

O que sugiro é o time experimentar Mob Programming um turno por semana, ou um turno por iteração/sprint. Quem sabe decidir quais tipos de tarefas ou histórias de usuário/requisitos serão melhor desenvolvidas com Mob Programming. Ou quem sabe para troca de conhecimento? Ou melhoria do padrão de código? O time deve experimentar e então decidir.

Mob Programming, tornando pessoas incríveis!

A expressão bastante utilizada pelo Woody Zuill, um dos que estavam presentes no time que criou Mob Programming, utiliza bastante a expressão Turn Up the Good (Aumente o que é Bom). Focar nas melhores qualidades das pessoas e do time. Isso vem muito de Psicologia Positiva, de se focar no que há de melhor nos indivíduos, nos times e nas organizações, e não tanto em problemas. Isso faz com que as pessoas se tornem e se sintam realmente incríveis. Agradeço a presença de todos participantes, na foto abaixo!

Como é um dia de trabalho num time e numa organização em Mob Programming?

Veja como é um dia de trabalho de um time em Mob Programming:
https://www.youtube.com/watch?v=p_pvslS4gEI

E veja como é diversos times trabalhando numa empresa em Mob Programming:
https://www.youtube.com/watch?v=dVqUcNKVbYg

Quer aprender na prática Mob Programming?

Dia 09/02/2019 haverá o workshop de Mob Programming em Porto Alegre https://www.sympla.com.br/workshop-de-mob-programming-uma-abordagem-agil-com-o-time-todo__446273

Você gostaria de praticar Mob Programming? Envie-me uma mensagem direta pelas redes sociais que com certeza lhe ajudarei.

Acompanhe os eventos, meetups e treinamentos que facilito em https://dionatanmoura.com/eventos/

Deixe uma resposta

Faça o login usando um destes métodos para comentar:

Logotipo do WordPress.com

Você está comentando utilizando sua conta WordPress.com. Sair /  Alterar )

Foto do Google+

Você está comentando utilizando sua conta Google+. Sair /  Alterar )

Imagem do Twitter

Você está comentando utilizando sua conta Twitter. Sair /  Alterar )

Foto do Facebook

Você está comentando utilizando sua conta Facebook. Sair /  Alterar )

Conectando a %s