Está en la página 1de 36

Qué es SCRUM

Scrum es un proceso en el que se aplican de manera regular un conjunto


de buenas prácticas para trabajar colaborativamente, en equipo, y
obtener el mejor resultado posible de un proyecto. Estas prácticas se apoyan
unas a otras y su selección tiene origen en un estudio de la manera de
trabajar de equipos altamente productivos.

En Scrum se realizan entregas parciales y regulares del producto final,


priorizadas por el beneficio que aportan al receptor del proyecto. Por ello,
Scrum está especialmente indicado para proyectos en entornos complejos,
donde se necesita obtener resultados pronto, donde los requisitos son
cambiantes o poco definidos, donde la innovación, la competitividad,
la flexibilidad y la productividad son fundamentales.

Scrum también se utiliza para resolver situaciones en que no se está


entregando al cliente lo que necesita, cuando las entregas se alargan
demasiado, los costes se disparan o la calidad no es aceptable,
cuando se necesita capacidad de reacción ante la competencia,
cuando la moral de los equipos es baja y la rotación alta, cuando es
necesario identificar y solucionar ineficiencias sistemáticamente o
cuando se quiere trabajar utilizando un proceso especializado en el
desarrollo de producto.

Ver en detalle cuales son los beneficios de Scrum, sus fundamentos y sus requisitos.

El proceso
En Scrum un proyecto se ejecuta en ciclos temporales cortos y de duración
fija (iteraciones que normalmente son de 2 semanas, aunque en algunos
equipos son de 3 y hasta 4 semanas, límite máximo de feedback de
producto real y reflexión). Cada iteración tiene que proporcionar un
resultado completo, un incremento de producto final que sea susceptible de
ser entregado con el mínimo esfuerzo al cliente cuando lo solicite.
El proceso parte de la lista de objetivos/requisitos priorizada del producto,
que actúa como plan del proyecto. En esta lista el cliente (Product
Owner) prioriza los objetivos balanceando el valor que le aportan
respecto a su coste (que el equipo estima considerando la Definición de
Hecho) y quedan repartidos en iteraciones y entregas.
Las actividades que se llevan a cabo en Scrum son las siguientes (los
tiempos indicados son para iteraciones de 2 semanas):
Planificación de la iteración
El primer día de la iteración se realiza la reunión de planificación de la
iteración. Tiene dos partes:

1. Selección de requisitos (2 horas). El cliente presenta al equipo la lista de


requisitos priorizada del producto o proyecto. El equipo pregunta al cliente
las dudas que surgen y selecciona los requisitos más prioritarios que prevé
que podrá completar en la iteración, de manera que puedan ser entregados
si el cliente lo solicita.
2. Planificación de la iteración (2 horas). El equipo elabora la lista de tareas
de la iteración necesarias para desarrollar los requisitos seleccionados. La
estimación de esfuerzo se hace de manera conjunta y los miembros del
equipo se autoasignan las tareas, se autoorganizan para trabajar incluso en
parejas (o grupos mayores) con el fin de compartir conocimiento (creando
un equipo más resiliente) o para resolver juntos objetivos especialmente
complejos.

Ejecución de la iteración
Cada día el equipo realiza una reunión de sincronización (15 minutos),
normalmente delante de un tablero físico o pizarra (Scrum Taskboard). El
equipo inspecciona el trabajo que el resto está realizando (dependencias
entre tareas, progreso hacia el objetivo de la iteración, obstáculos que
pueden impedir este objetivo) para poder hacer las adaptaciones necesarias
que permitan cumplir con la previsión de objetivos a mostrar al final de la
iteración. En la reunión cada miembro del equipo responde a tres preguntas:

 ¿Qué he hecho desde la última reunión de sincronización para ayudar al


equipo a cumplir su objetivo?
 ¿Qué voy a hacer a partir de este momento para ayudar al equipo a cumplir
su objetivo?
 ¿Qué impedimentos tengo o voy a tener que nos impidan conseguir nuestro
objetivo?

Durante la iteración el Facilitador (Scrum Master) se encarga de que el


equipo pueda mantener el foco para cumplir con sus objetivos.

 Elimina los obstáculos que el equipo no puede resolver por sí mismo.


 Protege al equipo de interrupciones externas que puedan afectar el objetivo
de la iteración o su productividad.

Durante la iteración, el cliente junto con el equipo refinan la lista de


requisitos (para prepararlos para las siguientes iteraciones) y, si es
necesario, cambian o replanifican los objetivos del proyecto (10%-15% del
tiempo de la iteración) con el objetivo de maximizar la utilidad de lo que se
desarrolla y el retorno de inversión.

Inspección y adaptación
El último día de la iteración se realiza la reunión de revisión de la iteración.
Tiene dos partes:

1. Revisión (demostración) (1,5 horas). El equipo presenta al cliente los


requisitos completados en la iteración, en forma de incremento de producto
preparado para ser entregado con el mínimo esfuerzo. En función de los
resultados mostrados y de los cambios que haya habido en el contexto del
proyecto, el cliente realiza las adaptaciones necesarias de manera objetiva,
ya desde la primera iteración, replanificando el proyecto.
2. Retrospectiva (1,5 horas). El equipo analiza cómo ha sido su manera de
trabajar y cuáles son los problemas que podrían impedirle progresar
adecuadamente, mejorando de manera continua su productividad. El
Facilitador se encargará de eliminar o escalar los obstáculos identificados
que estén más allá del ámbito de acción del equipo.

Ver en detalle las diferentes actividades, responsabilidades y herramientas en cómo


funciona Scrum.

Cómo funciona Scrum

Actividades

 Planificación de la iteración (Sprint Planning)


 Ejecución de la iteración (Sprint)
 Reunión diaria de sincronización del equipo (Scrum Daily Meeting)
 Demostración de los requisitos completados (Sprint Review)
 Retrospectiva (Sprint Retrospective)
 Refinamiento de la lista de requisitos y cambios en el proyecto

Responsabilidades

 Cliente (Product Owner)


 Facilitador (Scrum Master)
 Equipo de desarrollo (Team)

Herramientas

 Lista de requisitos priorizada (Product Backlog)


 Lista de tareas de la iteración (Sprint Backlog)
 Gráficos de trabajo pendiente (Burndown Chart)

Secciones relacionadas
 Fundamentos de Scrum
 Requisitos para poder utilizar Scrum

Herramientas que se suelen utilizar en Scrum


 Definición de hecho (DoD)
 Historias de usuario y criterios de aceptación
 Tablero de tareas
 Planning Poker
 Velocidad del equipo
 Principios de Lean Software Development

Conceptos y técnicas relacionadas


 Base de conocimiento
 El expendedor – Juego de simulación de Scrum
HERRAMIENTAS

Lista de objetivos / requisitos priorizada


(Product Backlog)
La lista priorizada de objetivos/requisitos representa la visión y expectativas
del cliente respecto a los objetivos y entregas del producto o proyecto

El orden de sus ítems viene determinado por el valor que aporta al cliente final respecto
a riesgos y coste estimado de completarlo (ROI). Es una planificación estratégica que
evoluciona a lo largo de toda la vida del producto/proyecto, debido a cambios de
necesidades del cliente, feedback del mercado, aparición de nuevas ideas, dificultades
tecnológicas, etc.

El cliente es el responsable de crear y gestionar la lista (con la ayuda


del Facilitador y del equipo, quien proporciona el coste estimado de
completar cada requisito). Dado que reflejar las expectativas del cliente,
esta lista permite involucrarle en la dirección de los resultados del producto
o proyecto.

 Contiene los objetivos/requisitos de alto nivel del producto o proyecto, que se


suelen expresar en forma de historias de usuario. Para cada objetivo/requisito se
indica el valor que aporta al cliente y el coste estimado de completarlo. La lista
está priorizada balanceando el valor que cada requisito aporta al negocio frente al
coste estimado que tiene su desarrollo, es decir, basándose en el Retorno de la
Inversión (ROI).
 En la lista se indican las posibles iteraciones y las entregas (releases) esperadas
por el cliente (los puntos en los cuales desea que se le entreguen los
objetivos/requisitos completados hasta ese momento), en función de la velocidad
de desarrollo del (los) equipo(s) que trabajará(n) en el proyecto. Es conveniente que
el contenido de cada iteración tenga una coherencia, de manera que se reduzca el esfuerzo de
completar todos sus objetivos.
 La lista también tiene que considerar los riesgos del proyecto e incluir los
requisitos o tareas necesarios para mitigarlos.
Antes de iniciar la primera iteración, el cliente debe tener definida la meta del
producto o proyecto y la lista de requisitos creada. No es necesario que la lista
sea completa ni que todos los requisitos estén detallados al mismo nivel.
Basta con que estén identificados y con suficiente detalle los requisitos más
prioritarios con los que el equipo empezará a trabajar. Los requisitos de iteraciones
futuras pueden ser mucho más amplios y generales. La incertidumbre y
complejidad propia de un proyecto hacen conveniente no detallar todos los
requisitos hasta que su desarrollo esté próximo. De esta manera, el esfuerzo de
recoger, detallar y desarrollar el resto de requisitos (menos prioritarios) está
repartido en el período de ejecución del proyecto. En el caso del desarrollo de un
producto, la lista va evolucionando durante toda la vida del producto (los requisitos
“emergen”). En el caso de un proyecto, conforme éste avance irán apareciendo los
requisitos menos prioritarios que falten. Esto produce varias ventajas:

 Se evita caer en parálisis de análisis al inicio del proyecto, de manera que se puede iniciar
antes el desarrollo y el cliente puede empezar a obtener resultados útiles.
 Se evita analizar en detalle requisitos no prioritarios que podrían cambiar durante el transcurso
del proyecto, dado que el cliente conocerá mejor cuál ha de ser el resultado a conseguir, o bien
por que podrían ser reemplazados por otros.
 Puede llegar a un punto del proyecto en que no valga la pena analizar ni desarrollar los
requisitos restantes, dado el poco retorno de inversión (ROI) que tienen.
Iteración de entrega (release sprint)

Cuando el cliente solicita una entrega de los objetivos/requisitos


completados hasta ese momento, el equipo puede necesitar añadir
una iteración de entrega, más corta que las iteraciones habituales, donde
realizar alguna tarea que no ha sido necesaria o posible hasta el momento
de la entrega final y acabar de corregir defectos detectados en la última
demostración.

Idealmente esta iteración de entrega no debería existir (o reducirse a tareas


mínimas dentro de una iteración) si:

 Se ha trabajado con una buena Definición de Hecho durante cada iteración del proyecto.
 Se hacen entregas muy cortas cada poco tiempo, con lo que la cantidad de cosas a entregar,
integrar y probar es pequeña.
 Se está realizando un esfuerzo de automatización de estas tareas de pruebas, iteración y
entrega durante todo el proyecto (con lo cual se gana en eficiencia y seguridad).

Uso de la lista de objetivos priorizada


 Para medir la velocidad de desarrollo del equipo, ver una progresión constante y
extrapolar la fecha de las entregas, es conveniente seguir las siguientes
recomendaciones:
 Los requisitos deben tener un esfuerzo semejante para ser completados.
 La estimación de un requisito no debe ser superior a 10 días (si las
iteraciones son de 20 días laborables).
 Cada requisito tiene asociado un factor de complejidad, que permite ajustar
su coste estimado en función de la incertidumbre de la complejidad de su desarrollo
en el momento de introducirlo en la lista. Este factor de coste se irá ajustando
conforme las iteraciones avancen y el equipo conozca mejor el producto o proyecto,
su contexto y su velocidad de desarrollo con las herramientas y tecnologías que
utiliza.
 Si un requisito depende de otro, se coloca en algún punto por debajo del
que depende.
 Si un requisito no se finaliza en una iteración, se le vuelve a poner en alguna de las
siguientes iteraciones, indicando el coste pendiente de desarrollo.
 El “origen” permite saber quién podría participar en la definición de un
objetivo/requisito y sería conveniente que estuviese presente en el momento
de su demostración.

El progreso del proyecto y su velocidad con respecto a requisitos completados se


muestra en un gráfico de trabajo pendiente (Burndown chart).
Artículos relacionados
 Refinamiento de la lista de requisitos y cambios en el proyecto
 Planificación ágil vs planificación tradicional
 Introducción a la estimación y planificación ágil
 Videos cortos sobre planificación ágil
 Estimación y planificación ágil – Resultados del quinto encuentro ágil en Barcelona
 Creación de Product Backlog – III encuentro ágil en Barcelona
 Planificación ágil de proyectos dependientes
 Métricas ágiles y cuadro de mandos integral para Scrum
 Métricas ágiles y valor – VI encuentro ágil en Barcelona

Lista de tareas de la iteración


(Sprint Backlog)
Subconjunto de objetivos/requisitos del Product Backlog seleccionado para
la iteración actual y su plan de tareas de desarrollo. El equipo lo elabora en
la reunión de planificación de la iteración (Sprint planning) seleccionando lo
que prevé que podrá completar y demostrar al cliente al finalizar la iteración,
en forma de incremento de producto preparado para ser entregado.

El Sprint Backlog una planificación táctica del trabajo a realizar en la iteración actual.

Esta lista permite ver las tareas donde el equipo está teniendo problemas y
no avanza, con lo que le permite tomar decisiones al respecto.

Para cada uno de los objetivos/requisitos se muestran sus tareas, el


esfuerzo pendiente para finalizarlas y la autoasignación inicial que han hecho
los miembros del equipo.
El progreso de la iteración y su velocidad con respecto a tareas u horas pendientes se
puede mostrar mediante un gráfico de trabajo pendiente (Burndown chart).

Uso de la lista

 Los objetivos/requisitos están ordenados por orden de prioridad para el


cliente.
 Por ello, signos de falta de foco, problemas o impedimentos serían que se estén
completando objetivos que no son los primeros de la lista, así como
tener demasiados objetivos/requisitos en progreso simultáneamente.
 Si una tarea depende de otra, se coloca en algún punto por debajo de la que depende.
 Las tareas deben estar identificadas de manera que tengan un coste
semejante para ser completadas, entre 4 y 16 horas. Este tamaño
permitirá:
 Que las tareas sean suficientemente pequeñas como para poder detectar progreso
o estancamiento de manera diaria.
 Que las tareas no sean muy pequeñas, que sean suficientemente relevantes, no
generen ruido ni microgestión.
 Medir la velocidad de desarrollo del equipo y extrapolar si es posible
finalizarlas dentro de la iteración.

El tablero de tareas (Scrum Taskboard)

La lista de objetivos a completar en la iteración (Product Backlog Items) se puede


gestionar mediante un tablón de tareas (Scrum Taskboard). Al lado de cada objetivo se
ponen las tareas necesarias para completarlo, en forma de post-its, y se van moviendo
hacia la derecha para cambiarlas de estado (pendientes de iniciar,
en progreso, hechas). Para cada miembro del equipo se puede utilizar adhesivos de
colores más pequeños sobre cada tarea, de manera que se pueda ver en qué tareas
está trabajando cada cual.

El equipo elabora esta lista de tareas en la segunda parte de la reunión de


planificación de la iteración. La lista va evolucionando (nuevas tareas,
cambios, estado, esfuerzo pendiente, …) a medida que la iteración avanza,
especialmente durante la reunión diaria de sincronización.

Este tablón o cuadro de mandos actúa como radiador de información tanto para el
equipo como para cualquier otra persona relacionada con el proyecto.

En el siguiente artículo se muestra cómo construirlo y un ejemplo de su uso: Ejemplo


de uso del tablero o pizarra de tareas (Scrum Taskboard).

Ejemplo de uso del tablero o pizarra de


tareas (Scrum Taskboard)
La lista de objetivos a completar en la iteración (Product Backlog Items) se puede gestionar mediante un
tablero o pizarra de tareas (Scrum Taskboard) que actúa como radiador de información. A continuación
se muestra cómo construirlo y un ejemplo de su uso.

Construcción del tablero


Material

 Pizarra blanca o cartón pluma, como mínimo de 100 cm x 70 cm, marcando las áreas del
tablero con cinta adhesiva de colores.
 Idealmente, el equipo debería de disponer de una superficie el doble de grande, para
poderse ver y leer bien a cierta distancia, así como tener suficiente espacio físico para
hacer delante suyo la reunión diaria de sincronización (Scrum daily meeting).
 En su defecto, se puede utilizar papelógrafo o corcho.
 Rotuladores permanentes de color negro, rojo y verde.
 Regla de 50 cm.

Dimensiones

La distribución de zonas se ha realizado de la siguiente manera:

 En la parte superior se dispone una fila específica para tareas no planificadas, aquellas que
no son parte de los requisitos/objetivos de la iteración pero que es necesario hacer de manera
urgente (errores en producción, urgencias del cliente, etc.). De esta manera podremos
visualizar cuanto somos de reactivos en lugar de planificados dentro de la iteración.
 A continuación hay una fila reservada para la mejora continua, donde se podrán las tareas
fruto de retrospectivas anteriores y que queremos que realizar en esta iteración. Sólo
pondremos aquí aquellas tareas que no sean asociables a un objetivo propio de la iteración.
 Se ha dejado más espacio para la columna de tareas no iniciadas, de manera que quepan
todas las que se identifican en la reunión de planificación de la iteración (sprint planning). Notar
que el espacio para tareas en curso es menor, dado que deberían ser las mínimas posibles
para favorecer el flujo eliminando el multitasking. Similarmente, el número de objetivos abiertos
en curso (WIP, Work In Progress) debería ser el mínimo posible y ser resueltos de arriba a
abajo, según la prioridad indicada en el Product Backlog.
 La zona de impedimentos está destinada a la lista de obstáculos que pueden impedir que el
equipo avance, que consiga los objetivos de la iteración o del proyecto, u otros riesgos que
requieren una atención especial. Es conveniente indicar quien es el responsable de su solución
(un miembro del propio equipo o el Facilitador (Scrum Master), dado que es una de sus
principales atribuciones). Se gestionan de manera similar a las tareas (pendientes, en curso,
hechos).
 La zona de retrospectiva servirá para ir anotando durante la iteración los aspectos que están
funcionado bien (+, Pluses) así como los problemas que vamos identificando (Δ, Deltas).
 En la zona libre de la derecha situaremos, encima, información propia del proyecto y, debajo,
información propia de la iteración (explicado más adelante).

Resultado de la construcción

Las ventajas de utilizar como base el cartón pluma son:

 Su poco peso, lo cual permite llevar el tablero fácilmente desde la zona de trabajo del equipo a
una sala para, por ejemplo, hacer la reunión de planificación de iteración (sprint planning).
 Su modularidad, que permite adaptarlo a diferentes tamaños de equipo (las dimensiones del
tablero de este ejemplo son las adecuadas para un equipo de 5 personas). Además de existir
formatos de tamaño mayor e inferior, si es necesario en nuestro proyecto, podemos utilizar
varios tableros y disponerlos uno al lado de otro, cambiar su orientación (horizontal-vertical),
etc.
El tablero como radiador de la información de
referencia para el equipo
El tablero es un radiador de información, difunde el estado actual de la iteración (actualizado en
la reunión diaria de sincronización (Scrum daily meeting), por lo que debe estar visible desde los puestos
de trabajo del equipo con sólo hacer un movimiento de cabeza. También es especialmente útil en las
reuniones que realizamos durante la iteración, por lo que en él ponemos aquella información que
queramos consultar fácilmente cuando tengamos conversaciones delante del tablero:

 La leyenda con el nombre de los miembros del equipo, su código de colores, fotos.
 Información general del proyecto
 La definición de hecho, que nos servirá como base inicial para hacer el despiece de
objetivos de la iteración en tareas durante la reunión de Planificación de la iteración (Sprint
planning).
 La lista de objetivos priorizada del proyecto (Product Backlog).
 Modelos del producto que se está desarrollando, a los que referirnos cuando expliquemos
algo a los demás. De esta manera todos los miembros del equipo tendrán una misma
visión, les sirvirá de apoyo cuando comuniquen cosas y ayudará a que utilicen una misma
nomenclatura. Típicamente: diagrama de entidades del dominio, procesos o bloques
funcionales e integraciones, etc.
 Indicadores del proyecto: Product Backlog Burndown Chart, tendencias de defectos, etc.
 Información propia de la iteración
 El objetivo de la iteración.
 El gráfico de horas pendientes de la iteración (Sprint burndown chart).
 Un calendario con los principales eventos del mes que tenemos que tener en cuenta.
 Cualquier otra información que nos interese tener muy a mano.
Planificación de la iteración (Sprint Planning)
Durante la reunión de planificación de la iteración, se va incorporando al tablero siguiente información:

 En la columna de la izquierda se irán situando los objetivos de producto (Product Backlog


Items) que el equipo se compromete a completar en la iteración, ordenados por prioridad para
el cliente (Product Owner). Estos objetivos se pueden redactar, por ejemplo en formato
de historias de usuario o, simplemente, con un título y un detalle (preferiblemente que indique
qué pruebas se van a realizar para demostrar que el objetivo está conseguido).
 A la derecha de cada objetivo se pondrán, en la columna “pendientes”, las tareas necesarias
para poder completarlo, indicando las horas estimadas para su resolución, que iremos
actualizando en las reuniones diarias de sincronización (Scrum daily meetings).
 En su zona específica, dispondremos las tareas de mejora continua que se han derivado de
la retrospectiva de la iteración anterior, que queremos resolver durante esta iteración y que, por
tanto, consumirán tiempo de alguna persona.

De esta manera visualizaremos todos los tipos de tareas en que trabajan los miembros
del equipo.
Ejecución de la iteración

 Ponemos en color rosa las nuevas tareas que vayan apareciendo, sean:

 Tareas asociadas a objetivos / requisitos / historias de usuario que no fueron
identificadas en la reunión de planificación de la iteración.
 Tareas inesperadas y no asociadas a objetivos pero que exigen nuestra resolución
dentro de la propia iteración (en la zona “no planificado”).
 De esta manera podremos obtener métricas de trabajo no planificado [2] y en la
retrospectiva revisaremos cuáles son las tareas que han aparecido de color rosa, lo
cual nos permitirá saber, por ejemplo, si es que tenemos que mejorar nuestra
definición de hecho o bien si tenemos que reflexionar y realizar alguna acción para
intentar minimizar tareas no previstas.


 Marcamos con un gomet rojo los objetivos y/o las tareas con más riesgos, aquellos que
queremos tener controlados con más atención.


 Cuando suceda alguna cosa que queramos comentar en la retrospectiva, la ponemos en
su zona específica, en función de que sea una cosa que se está haciendo bien y se quiere
recordar para memorizar y/o incluir como buena práctica (+, Plus) o bien una cosa una cosa
a mejorar (Δ, Delta).


 Ponemos los impedimentos, riesgos o cualquier otra cosa crítica que se tenga que ir
resolviendo en la zona a tal efecto, especialmente las acciones a realizar que están fuera
del alcance del equipo y que sean para el Facilitador (Scrum Master). Los gestionamos de
la misma manera que cualquier otra tarea, poniéndolos como pendientes, en curso o
hechos.

 Podemos poner en otro color, por ejemplo en azul, los objetivos de la iteración siguiente que
iniciamos en la iteración actual, para saber que estamos avanzando, pero también para no
perder el foco en que lo primero que tenemos que completar son los comprometidos para la
iteración. De esta manera podremos obtener métricas de trabajo avanzado [2] y reflexionar en
la retrospectiva.

[Los colores aquí indicados para objetivos de la iteración (ítems del Product Backlog) y para las tareas
son orientativos y se pueden ampliar en función de otros aspectos que queramos señalizar de manera
especial (ítems de temas diferentes, tareas de corrección de errores, etc.)].
Trucos (sólo si es necesario)
 Utilizar una marca específica para las tareas más prioritarias (reservar el color rojo para
indicar problemas o riesgos).
 Poner colores diferentes en función del tipo de tarea (análisis/diseño, construcción, errores).
 Poner 1 punto negro por cada día que una tarea se retrasa, para que el equipo vea si hay
algún peligro y para poder reflexionar en la retrospectiva.
 Poner 1 punto naranja cada vez que un objetivo/tarea se reabre por que no pasa las
pruebas / control de calidad / aceptación y vuelve “hacia atrás”.
 Sólo mover tareas a “Hechas” en la reunión diaria de sincronización, para que todo el mundo
sea conciente del avance. Para ello, cuando alguien acaba una tarea, la marca como
“hecha” pero no la mueve.
 Una vez acabada una tarea, si es necesario que otra persona haga control de calidad (peer
review y/o pruebas), se puede marcar la tarea indicando “Revisar”, por ejemplo con un post-
it más pequeño. Se puede utilizar el siguiente convenio: un gomet a la izquierda para identificar
a quien “hará” y otro a la derecha para identificar a quien “revisará”.
 Notar que la marca “Revisar” es equivalente a tener un estado de tareas (columna)
llamado Revisar, por lo que evita crear una “tarea Y” específica para hacer el control de
calidad de la “tarea X” o tener una columna específica de “Revisar”, especialmente si este
estado no es aplicable a la mayoría de tareas. Sin embargo, se podría utilizar alguno de
estos sistemas de control si se considera necesario, por ejemplo si el 80% de las tareas
necesita revisión.
 Poner un número en las tareas para indicar el orden.
 Poner en las tareas el ID o nombre abreviado de la historia de usuario (por si se caen).
 Tener una zona de Parking para los siguientes objetivos si no caben en el tablero o para tareas
que el equipo va detectando que sería necesario hacer antes de finalizar la iteración pero que
todavía no han sido clasificadas en objetivos.

Material para trabajar con el taskboard


A continuación aparece el material utilizado para crear este taskboard pequeño
realizado en cartón pluma. Idealmente, el equipo debería de disponer de una superficie
el doble de grande (para poderse ver y leer bien a cierta distancia) y entonces utilizar
formatos de post-it algo mayores.

 Post-its rectangulares: 13 x 7,5 cm,


 2 paquetes color amarillo
 1 paquetes color azul (o verde)
 1 paquete color rosa (o naranja)
 Post-its cuadrados, 7,5 x 7,5 cm, a ser posible: super sticky
 4 paquetes color amarillo
 2 paquetes color verde
 2 paquetes color naranja
 1 paquete color lila
 1 paquete color rosa (o rojo)
 1 paquete color azul
 Post-its pequeños 5 x 4 Etiquetas post-its (2,5 x 7 cm), en 2 o 3 colores diferentes.
 6 paquetes color amarillo.
 1 paquete color rosa (o naranja)
 1 paquete color azul (o verde)
 Cinta adhesiva transparente.
 Cinta adhesiva de color o negra, 3M Temflex 1500 o TESA 4204.
 Tijeras.
 Gomets pequeños para asignación de 7 personas: 7 colores + rojo = 8 colores. Si es un tablero
de corcho: marcas/papelitos de colores y chinchetas.
 Rotuladores normales: negro, rojo, verde, azul.
 Rotuladores de pizarra blanca: negro, rojo, verde, azul.
 Borrador de pizarra blanca.
 Caja donde guardar todo el material anterior.

Agradecimientos
Me gustaría agradecer a las siguientes personas las ideas y consejos que me han ido proporcionando en
estos años de uso de tableros de Scrum:


 [1] Ángel Medinilla, por la sugerencia de utilizar cartón pluma como base.


 [2] Jordi Salvat y Alabart, por su artículo de métricas en Scrum en que explica el marcaje
especial de las tareas no identificadas en la reunión de planificación de iteración.

 [3] Xavier Quesada, por la fuente de recursos e inspiración que es su Visual Management
Blog (en inglés), donde aparecen más ejemplos como el siguiente:
Gráficos de trabajo pendiente
(Burndown charts)
Un gráfico de trabajo pendiente a lo largo del tiempo muestra la velocidad a la que se
está completando los objetivos/requisitos. Permite extrapolar si el Equipo podrá
completar el trabajo en el tiempo estimado.

Se pueden utilizan los siguientes gráficos de esfuerzo pendiente:

 Días pendientes para completar los requisitos del producto o proyecto (product
burndown chart), realizado a partir de la lista de requisitos priorizada (Product
Backlog).
 Horas pendientes para completar las tareas de la iteración (sprint burndown chart),
realizado a partir de la lista de tareas de la iteración (Iteration Backlog).

Este tipo de gráfico permite realizar diversas simulaciones: ver cómo se aplazan las
fechas de entrega si se le añaden requisitos, ver cómo se avanzan si se le quitan
requisitos o se añade otro equipo, etc.
RESPONSABILIDADES

Cliente (Product Owner)

Su principal misión es encargarse de que exista una priorización clara de


los objetivos a conseguir, con el propósito de maximizar el valor del trabajo que lleva a
cabo el equipo.

Las responsabilidades del Cliente / Product Owner (que puede ser interno o externo a
la organización que realiza el desarrollo del producto) son:

 Conocer el mercado y los comportamientos de los clientes / usuarios finales, con muy
buena visión de Negocio.
 Ser el representante de todas las personas interesadas (stakeholders) para conseguir una
buena definición de los objetivos del producto o proyecto y de los resultados esperados.
 Las “personas interesadas” pueden ser internas o externas a la organización: promotores
del proyecto y usuarios finales.
 Idealmente el Product Owner también debería ser algún tipo de usuario, un consumidor
final del producto, para poder experimentar directamente si se consiguen los beneficios que
hipotéticamente le debería aportar.
 Encargarse de que exista una priorización clara de los objetivos a conseguir. De este modo,
dirige los resultados del proyecto para maximizar su ROI (Return Of Investment):
 Es el propietario de la planificación del proyecto: crear y mantener la lista priorizada con los
requisitos necesarios para cubrir los objetivos del producto o proyecto, conocer el valor que
aportará cada requisito y calcula el ROI a partir del coste de cada requisito (estimación que
le proporciona el equipo).
 Repartir los objetivos/requisitos en iteraciones, de manera que prioriza tanto el proporcionar
beneficios al usuario final como reducir riesgos respecto hipótesis) y establece un
calendario de entregas.
 Antes de iniciar cada iteración, replanificar el proyecto en función de los requisitos que
aportan más valor en ese momento, de los requisitos completados en la iteración anterior y
del contexto del proyecto en ese momento (demandas del mercado, movimientos de la
competencia, etc.).
 Actuar como interlocutor único ante el equipo, con autoridad para tomar decisiones (es decir,
con libertad para decidir qué hacer de manera alineada con los objetivos de su área de trabajo,
que no se vea invalidada por personas en una posición superior).

 Colaborar con el equipo para planificar, revisar y dar detalle a los objetivos de cada
iteración:
 Participar en la reunión de planificación de iteración, proponiendo los requisitos más
prioritarios a desarrollar, respondiendo a las dudas del equipo y detallando los requisitos
que el equipo se comprometer a hacer.
 Estar disponible durante el transcurso de la iteración para responder a las preguntas que
puedan aparecer.
 No cambiar los requisitos que se están desarrollando en una iteración, una vez está
iniciada.
 Participar en la reunión de demostración de la iteración, revisando los requisitos
completados.
 Proporcionar suficiente dedicación para hacer este trabajo (usualmente un Product Owner no
suele poder estar con más de 1-2 equipos, en función del tipo de producto y equipos).
 Notar que una distancia de 3-5 metros del equipo puede llegar a ser una barrera demasiado
alta para interactuar de manera ágil con el equipo (a menos que se encuentre físicamente
en otra ciudad). Sería difícil de justificar que el Product Owner esté situado en la misma
ciudad y no esté la mayor parte del tiempo sentado con sus equipos.

El éxito de una transformación Agile está fuertemente ligado a disponer de buenos


Product Owners, ya que son claves para confirmar hipótesis de valor en tiempos cortos,
así como ser embajadores de cambio a nivel social (con sus peers) y jerárquico (con
Product Management y stakeholders).

Por ello, una buena selección de Product Owners (y una esfuerzo especial en su
coaching de Producto/Cliente) es fundamental para un inicio de transformación
ágil exitoso, es decir, aportar resultados a la empresa de manera más ágil.

Otros roles
 El facilitador (Scrum Master).
 El equipo.

Facilitador (Scrum Master)

Su principal misión es conseguir un equipo de alto


rendimiento (entendiendo como equipo al Equipo de desarrollo y al Cliente / Product
Owner, así como sus relaciones con la organización y stakeholders). Se encarga de
conseguir el equipo que conozca y sienta los principios y valores de Agile, así como
la teoría y prácticas de Scrum, con el objetivo de que los usen en sus procesos de toma
de decisiones. El Scrum Master actúa como facilitador de reuniones donde pensar de
manera conjunta y quita los obstáculos más allá del equipo que le impiden ser ágil.

De este modo, es el coach y lider al servicio del equipo, llevando a cabo las siguientes
responsabilidades:

 Velar por que todos los participantes del proyecto sigan los valores y principios ágiles,
las reglas y proceso de Scrum y guiar la colaboración intraequipo y con el cliente /
Product Owner) de manera que las sinergias sean máximas. Esto implica:
 Asegurar que exista una lista de requisitos priorizada y que esté preparada antes de la
siguiente iteración.
 Facilitar las reuniones de Scrum (planificación de la iteración, reuniones diarias de
sincronización del equipo, demostración, retrospectiva), de manera que sean productivas,
se piense de manera conjunta, se creen sinergias y se consigan sus objetivos.
 Enseñar al equipo a autogestionarse. No da respuestas, si no que guía al equipo con
preguntas para que descubra por sí mismo una solución.

 Conocer el grado de motivación de cada uno de los miembros del equipo, trabajarla con ellos
y/o con las personas de la organización más relacionadas con este aspecto.

 Quitar impedimentos que el equipo tiene en su camino para conseguir el objetivo de cada
iteración (proporcionar un resultado útil al cliente de la manera más efectiva) y poder finalizar el
proyecto con éxito. Estos obstáculos se identifican de manera sistemática en las reuniones
diarias de sincronización del equipo y en las reuniones de retrospectiva.

 Proteger y aislar al equipo de interrupciones externas durante la ejecución de la


iteración (introducción de nuevos requisitos, “secuestro” no previsto de un miembro del equipo,
etc.). De esta manera, el equipo puede mantener su productividad y el compromiso que
adquirió sobre los requisitos que completaría en la iteración [notar, sin embargo, que el equipo
debe reservar tiempo para colaborar con al cliente en la preparación de la lista de requisitos
para la próxima iteración].

 Trabajar con otros Scrum Masters y el equipo de transformación / mejora continua con el
objetivo de que la organización sea cada vez más ágil.

Para poder conseguir su misión, es primordial que el Scrum Master esté sentado de
manera continua donde está la mayoría del equipo (normalmente donde está el equipo
de desarrollo), que sea un compañero mas, que forme parte de su día a día para poder
ayudarles a identificar cualquier área de mejora, así como estar a disponible siempre y
cuando se le necesite.

Notar que una distancia de 3-5 metros del equipo puede llegar a ser una barrera
demasiado alta para poder descubrir los comportamientos y tipos de relaciones que
hay entre sus miembros, y los impedimentos que les están dificultando el día a día.

Artículos relacionados
 Auto-organización – Fundamentos y relación con la motivación intrínseca
 Motivación de personas y liderazgo.
 El buen gestor de un equipo ágil
 Skills en un equipo ágil

 Otros roles
 El cliente (Product Owner).
 El equipo de desarrollo.

Equipo de desarrollo (Development Team)

El equipo en Agile incluye al Cliente / Product


Owner y al Facilitador / Scrum Master. Cuando se habla específicamente de “equipo de
desarrollo” se refiere al conjunto de personas más “técnicas” que de manera conjunta
desarrollan el producto del proyecto. Tienen un objetivo común, comparten la
responsabilidad del trabajo que realizan (así como de su calidad) en cada iteración y en
el proyecto.

Para ir alcanzando un estado de alto rendimiento, este equipo es:

 Autónomo y multidisciplinar.
 Agile se basa en ir desarrollando un producto “tangible” de forma iterativa para
obtener feedback en intervalos cortos de tiempo sobre si el producto genera en el
cliente el resultado esperado. Para ello, idealmente el equipo no debe depender de otros
pues generaría esperas y retrasos en la entrega de valor (necesidad de coordinación,
integración e incluso falta de ownership), con lo cual sólo se puede hacer con equipos
multidisciplinares y autónomos del resto de la organización. De este modo:
 Los miembros del equipo disponen de las habilidades necesarias para poder identificar
y ejecutar todas las tareas que permiten proporcionar al cliente los requisitos previstos
en la iteración.
 Tienen que depender lo mínimo de personas externas al equipo, de manera que no se
ponga en peligro la previsión del trabajo a revisar al final de cada iteración.
 Se crea una sinergia que permite que el resultado sea más rico al nutrirse de las
diferentes experiencias, conocimientos y habilidades de todos, “colaboración creativa”.

El equipo de desarrollo ágil en ocasiones es llamado Squad al englobar, con una visión
más amplia, cualquier skill o rol necesario para incluir toda la cadena de
valor dentro del equipo, de modo que todos sus miembros están guiados por el mismo
propósito, conocen al cliente, el dominio y definen conjuntamente problema a
solucionar. En función de las necesidades para desarrollar el producto, el Squad
puede incluir a desarrolladores, UX, Ops, Data, … y, por supuesto, al Product Owner y
al Scrum Master.

 Tamaño de equipo de 5 a 9 personas.


 Para ser ágil, el tamaño del equipo está entre 5 y 9 personas.
 Por debajo de 5 personas cualquier imprevisto o interrupción sobre un miembro del
equipo puede comprometer seriamente la previsión de objetivos a mostrar al cliente /
Product Owner al finalizar la iteración.
 Por encima de 9 personas, la comunicación y colaboración real entre todos los
miembros se hace más difícil y se acaban formando subgrupos, donde todo el mundo
no está interesado por los mismos objetivos del Sprint (ver los requisitos de Scrum).
 De cualquier manera, se puede trabajar en Scrum con 3 personas y se ha utilizado en
proyectos con centenares de personas, agrupadas en varios equipos. Cuando es
necesario que más de un equipo trabaje de manera ágil en un mismo producto/proyecto,
existen diferentes técnicas que permiten esta colaboración (sincronización regular entre
Product Owners; Scrum de Scrums entre miembros de los equipos; ajustes de las
reuniones de Scrum para hacer algunas más generales/comunes y poder gestionar
dependencias conjuntas [como si se tratase de un fractal de reuniones, ver LESS], siempre
completando incrementos de producto de manera regular. De cualquier modo, hay que
recordar que el objetivo final es conseguir que cada equipo sea el máximo de
independiente de los otros para realmente poder ágiles.
 Estable y dedicado.
 Los equipos ágiles trabajan en iniciativas estratégicas (que se mantienen en el tiempo) o
bien van repitiendo tipos de proyectos similares (van ajustando su misión como equipo). Un
equipo de alto rendimiento cuesta tiempo conseguirlo (y después hay que aprovechar
esa performance), es un activo fundamental para la empresa y su building block básico, con
lo cual prevalecerá el interés por mantenerlo por encima de desmantelarlo.
 Dado que el equipo debe ser estable, sus miembros deben cambiar lo mínimo posible, para
poder aprovechar el esfuerzo que les ha costado construir sus relaciones interpersonales,
engranarse y establecer su organización del trabajo.
 Los miembros del equipo están dedicados a tiempo completo a esa iniciativa o proyecto,
para evitar dañar su productividad por cambios de tareas en diferentes proyectos, para
evitar interrupciones externas, para trabajar todos en las mismas prioridades y así poder
mantener la previsión de lo que se podría entregar en cada iteración.

 Se auto-organizan, tienen responsabilidad compartida y piensan juntos:


 Para crear sinergias con qué conseguir un resultado mejor en menos tiempo, en términos
de valor para cliente.
 Para mejorar su proceso de trabajo y el sistema que les rodea, reflexionando regularmente
(por ejemplo haciendo Retrospectivas) e introduciendo acciones de mejora en su backlog
de tareas a realizar.
 La manera de conseguir esto se basa en compartir información y que sus miembros confíen
entre ellos. Para ello, realiza de manera conjunta las siguientes actividades:
 Seleccionar los requisitos que prevén completar en una iteración, de forma que
estén preparados para ser entregados al cliente.
 Estimar la complejidad de cada requisito en la lista de requisitos priorizada del producto
o proyecto.
 En la reunión de planificación de la iteración, decidir cómo va a realizar su trabajo:
 Seleccionar los requisitos que pueden completar en cada iteración, realizando al
cliente las preguntas necesarias.
 Identificar todas las tareas necesarias para completar cada requisito.
 Estimar el esfuerzo necesario para realizar cada tarea.
 Cada miembro del equipo se autoasigna a las tareas.
 Durante la iteración, trabajar de manera conjunta para conseguir los objetivos de la
iteración. Cada especialista lidera el trabajo en su área y el resto colaboran si es
necesario para poder completar un requisito.
 Al finalizar la iteración:
 Demostrar al cliente los requisitos completados en cada iteración.
 Hacer una retrospectiva la final de cada iteración para mejorar de forma continua su
manera de trabajar.

 Están motivados.
 Las personas motivadas hacen cosas increíbles y, por otro lado, un equipo no motivado
difícilmente desarrollará un gran producto o estará comprometido con proporcionar un gran
servicio (lo cual lleva a clientes / usuarios finales a los que se mejora su vida y están más
contentos, que es lo que necesita la empresa).

 Están sentados juntos.


 Todos los miembros del equipo trabajan en la misma localización física, para poder
maximizar la comunicación entre ellos mediante conversaciones cara a cara, diagramas en
pizarras blancas, etc.
 De esta manera se minimizan otros canales de comunicación menos eficientes, que
hacen que las tareas se transformen en un “pasa pelota” o que hacen perder el tiempo
en el establecimiento de la comunicación (como cuando se llama repetidas veces por
teléfono cuando la persona no está en su puesto).
 Notar que una distancia de 3-5 metros entre miembros de un equipo puede llegar a ser
una barrera demasiado alta para favorecer una relación realmente ágil entre ellos,
encontrar soluciones juntos rápidamente y resolver impedimentos. Es decir, a partir de
esa distancia (o si las personas están en otros pisos o edificios de una ciudad) los
efectos pueden ser bastante contraproducentes, equivalentes a tener un equipo
distribuido.
 En el casos de equipos remotos, que no trabajen en la misma ciudad, es conveniente
garantizar un tiempo de calidad cara a cara, como mínimo:
 1-2 semanas para el inception inicial del proyecto e integración “social” de los miembros
del equipo.
 2 o más días por iteración, para actividades
como Refinements, Retrospectivas o Planificaciones de iteración.

 Interaccionan con Stakeholders.


 Este equipo interacciona frecuentemente con los Stakeholders para compartir conocimiento
de negocio, alinear prioridades y medir los resultados del valor entregado al cliente.

Para saber más


 Auto-organización – Fundamentos y relación con la motivación intrínseca
 Motivación de personas y liderazgo.
 Skills en un equipo ágil

Otros roles
 El facilitador (Scrum Master).
 El cliente (Product Owner).
Herramientas que se suelen utilizar en Scrum

Definición de Hecho (Definition of Done)


La Definición de Hecho (Definition of Done) permite:

 Tener siempre un producto “potencialmente entregable y usable” al finalizar cada


iteración, con el mínimo esfuerzo, i.e. no dejar trabajo pendiente para el final, escondido
“debajo de la alfombra”, que pueda impedir utilizar los resultados del proyecto lo antes posible.
 Esto permite saber claramente en qué punto real se está del proyecto y tomar buenas
decisiones al respecto sobre lo que se ha conseguido hasta ese momento y lo que todavía
no se sabe con certeza cuándo estará acabado. Con una buena Definición de Hecho,
el cliente podrá tomar decisiones correctas cuando al final de cada iteración el equipo le
haga una demostración de los requisitos completados: cambiar las prioridades en función
de la velocidad de desarrollo, solicitar una entrega del producto desarrollado hasta ese
momento, etc.
 Por otro lado, lo peor que podría suceder es que, aunque el equipo haya ido presentando
todos los objetivos / requisitos completados durante el proyecto (en cada iteración), se
podría dar el caso de que los días previos a una entrega de repente se den cuenta de que
hay que hacer mucho trabajo de integración y finalización (que podría haberse ido haciendo
antes, durante el proyecto). Esto también les dificultaría estimar cuándo tiempo necesitan
para acabar de terminar el producto (lo cual pondría en peligro la fecha de entrega).

 Establecer un criterio de calidad, define qué entregables y mínimos de calidad tienen se


tienen que cumplir en TODOS los objetivos / requisitos que se van a ir aceptando durante cada
iteración del proyecto.

La Definición de Hecho se acuerda entre el Product Owner (cliente) y el Equipo de


desarrollo al principio del proyecto y se puede ir mejorando durante su transcurso (si es
necesario precisar más las expectativas en cuanto a calidad global o del proceso de
trabajo o, simplemente, tras una Retrospectiva, para ir consiguiendo una mejor la
calidad del producto final).

Ejemplo de Definición de Hecho:


 El trabajo de todos los miembros del equipo de desarrollo tiene que estar totalmente integrado
en cada iteración.
 El trabajo de cada miembro del equipo ha sido revisado por al menos otro miembro del equipo.
 Todo el equipo considera que para cada objetivo/requisito se cumplen sus Criterios de
Aceptación.
 El trabajo en cada iteración tiene que cumplir con los requisitos de calidad X, Y, Z.
 Tiene que estar probado A, B, C (calidad externa, usabilidad, funcionalidad, seguridad).
 El producto sigue los estándares de calidad interna y ha sido refactorizado para conseguir
mantenibilidad.
 Tiene que estar documentado D, E, F.
 El Product Owner ha validado y aceptado el objetivo/requisito.
La Definición de Hecho en la “Fase de Planificación”
La Definición de Hecho se utiliza en la “fase cero” del proyecto (que incluye la
“Inception” del producto, donde se genera la Lista de requisitos priorizada (Product
Backlog) para que el equipo de desarrollo pueda realizar una buena estimación del
esfuerzo global necesario para poder hacer todos los objetivos/requisitos del proyecto.

La Definición de Hecho en la Planificación de la iteración


(Sprint Planning)
La Definición de Hecho tiene un impacto en tareas específicas a realizar en por el
equipo de desarrollo en cada iteración, por lo que se utiliza como guía para generar
tareas en la Planificación de la iteración (Sprint Planning) (además de los criterios de
validación de cada objetivo/requisito).

Criterios de Aceptación vs Definición de


Hecho
Cada objetivo/requisito tiene asociados sus criterios de aceptación, los cuales definen
cómo se va a probar/demostrar que un objetivo/requisito ha sido conseguido. Se
acuerdan entre el Product Owner (cliente) y el Equipo de desarrollo en una
conversación que permita reducir la ambigüedad en QUÉ se espera sobre cada
requisito / objetivo.

Los criterios de aceptación de los objetivos/requisitos a trabajar en una iteración se


recogen en la Planificación de la iteración (Sprint Planning) (o antes, si fuese necesario,
para empezar a preparar la información que se utilizará en el desarrollo del objetivo-
requisito).

Notar pues que el concepto de “Definición de Hecho”, transversal a todos los


temas (objetivos), es diferente del concepto de “Criterios de Aceptación, que
afecta a cada tema (objetivo) en particular.
En cada iteración, el equipo revisa los criterios de aceptación de cada objetivo /
requisito finalizado (y el cumplimiento de la Definición de Hecho general) antes de su
aceptación por el Product Owner. Es decir, tanto el Product Owner como el equipo de
desarrollo utilizan los criterios de aceptación (y la definición de hecho) como checklist
para aceptar cada tema y darlo por hecho.

Objetivos como historias de usuario


Siguiendo esta línea, el primer paso en la estimación y planificación ágil es
la creación del product backlog, o sea la definición del proyecto a
realizar. Se puede dividir en objetivos expresados como historias de
usuario (user stories), cada una aportando valor de negocios incremental e
individual. Una historia es un requisito de negocio visto desde el punto de
vista de un usuario. Se escriben con el siguiente formato: “Como xxx, quiero
hacer yyy con el objetivo de zzz“, donde, xxx es el tipo de Usuario (quien),
yyy es lo que el sistema debe permitir realizar (el qué) y zzz es el beneficio o
valor buscado (el por qué).
Ejemplo:
“Como cliente del banco, quiero pedir un préstamo para poder comprar una
casa” .

Las condiciones de satisfacción de los objetivos suelen ponerse en forma


de criterios de aceptación, pruebas que se realizarán para verificar si el
sistema se comporta de la manera esperada. Para ello se puede utilizar la
sintaxis de BDD (Behaviour Driven Development) siguiendo el siguiente
formato: “Dado aaa, cuando se produzca bbb, entonces ccc“, donde aaa es la
situación en la que se encuentra el sistema, bbb es un evento que lo hará
cambiar y ccc es el resultado. Esta técnica permite evitar la aparición de
errores por malos entendidos y evitar retrabajar (siguiendo los principios
Lean). Por ello es recomendable no empezar a desarrollar en una iteración
sin antes haber escrito los casos de prueba, especialmente por que es más
barato escribir texto y pensar en cómo desambiguar los requisitos que
arreglar errores importantes debido a su mal entendimiento.

Pero en la práctica no hace falta usar estos formatos, cualquier sintaxis


donde la acción sea clara y el beneficio buscado sea entendido por todos es
suficiente. Si no partimos de cero, podemos simplemente tomar los
requerimientos en cualquier formato que estén escritos (por ejemplo casos de
uso).

Es importante no confundir Criterios de Aceptación de cada objetivo (requisito


/ historia de usuario) con la Definición de Hecho (DoD) que tienen que cumplir
TODOS los requisitos.
Estimación con Planning Poker
El product backlog es, para ser exactos, una lista priorizada y estimada de
historias. Por ahora sólo tenemos historias. Falta estimarlas y priorizarlas. El
proceso de estimación se puede hacer utilizando una técnica
llamada planning poker (póker de planificación). El objetivo del planning
poker es obtener una medida de tamaño relativo de todas las historias
respecto a sí mismas.

La teoría es que resulta relativamente fácil decir “A es más grande que B y


que C” [no voy a entrar en detalle respecto a cómo efectuar planning poker,
dejándolo para otro artículo]. Lo importante de efectuar planning poker sobre
todo el backlog (a efectos de la planificación) es que da como resultado que
todas las historias han sido estimadas con muy poco esfuerzo. Pero no en
días/hombre como se haría tradicionalmente. Planning poker produce
estimaciones en una medida arbitraria de tamaño llamada story points o
“puntos de historia”. Los story points son específicos de cada equipo, no
pueden compararse entre diferentes equipos y a veces ni siquiera entre
diferentes proyectos del mismo equipo. Lo único que indican es el tamaño
relativo que tiene cada funcionalidad del backlog respecto a las demás. Lo
importante es que ahora tenemos el tamaño total del proyecto estimado en
una unidad llamada story points, y esto nos va a servir de mucho.

Priorización
La etapa de priorización es sencilla y depende exclusivamente del Product
Owner. Sabiendo ya el tamaño de las historias, debe priorizarlas por valor de
negocio. Notar que también es posible comenzar con la asignación de valor
y después aportar el tamaño, en todo caso, la priorización se realiza
balanceando el valor respecto al coste y respecto a los riesgos de cada
objetivo.

Una manera rápida de empezar a asignar valor a las historias es dividirlas en


3 grupos, según sean imperativas, importantes o cosméticas/prescindibles
(de manera que si se llega a una fecha de entrega predeterminada y no se
han completado por lo menos hemos aportado el máximo de valor posible).
Dentro de cada grupo nos resultará más fácil realizar una ordenación relativa
por valor y después asignarlo.

La prioridad puede cambiar todo el tiempo; pero el tamaño en story


points debe mantenerse fijo con la estimación original (o sea: como regla
general, no reestimar). Si aparecen historias nuevas, deben estimarse
utilizando el mismo criterio que se utilizó originalmente.

Ahora bien: todo esto todavía no nos dice nada respecto a cuánto durará o
costará el proyecto; pero al menos es un paso más respecto a como
estábamos antes, que solo teníamos el ballpark estimate. Si sólo pudiéramos
averiguar a cuántos días/hombre o días/equipo equivale un story point,
tendríamos nuestra estimación, y luego nuestra planificación.

Duración y proyección a partir de la


velocidad del equipo
El último paso, por lo tanto, es calcular la velocidad del equipo completando
objetivos a lo largo de las iteraciones. Así pues, la velocidad es la cantidad
de story points que se completan por iteración. Calcularla es sencilla: solo
hay que sentarse y esperar. En dos -como máximo tres- iteraciones, tendrás
una idea bastante clara de cuál es la velocidad del equipo y por lo tanto el
tamaño y duración del proyecto. Mientras tanto se puede ir construyendo
el burndown chart, cosa que no me animo a traducir (gráfico de quemado?).
El burndown chart nos muestra en el eje Y la cantidad total de story points del
proyecto, y sobre el eje X las iteraciones. Cada vez que se finaliza una
iteración, se completa un punto del gráfico, indicando la velocidad en ese
ciclo.

Si teníamos una fecha prefijada en la que queremos terminar el proyecto,


esto nos permite calcular la velocidad teórica a la que tendremos que ir para
alcanzar esa fecha. El burndown chart permite rápidamente y en todo
momento ver dos estadísticas vitales para la planificación: la estimación
actual de cuándo va a estar terminado el 100% del proyecto; y la
estimación del porcentaje de proyecto que va a estar terminado cuando
lleguemos a cierta fecha.

Conclusión
La estimación y planificación ágil permiten así en todo momento saber cuál
es la fecha estimada de finalización del proyecto, y en qué iteración
estará lista determinada funcionalidad. Un beneficio adicional que nos
brinda es que de existir complicaciones severas, que pongan en juego la
factibilidad del proyecto, éstas generalmente se ven expuestas bien
temprano, permitiendo cancelar el proyecto antes de incurrir en grandes
pérdidas. Por esto, sumado al hecho de que el desarrollo iterativo e
incremental garantiza que en todo momento se cuenta con el producto
listo para ser entregado (por ejemplo software funcionado), está el hecho de
que los métodos ágiles disminuyen enormemente los riesgos
tradicionales en el desarrollo de proyectos.

Artículos relacionados
 Refinamiento de la lista de requisitos y cambios en el proyecto
 Planificación ágil vs planificación tradicional
 Videos cortos sobre planificación ágil
 Planificación ágil con mapas de producto
 Estimación y planificación ágil – Resultados del quinto encuentro ágil en
Barcelona
 Creación de Product Backlog – III encuentro ágil en Barcelona
 Planificación ágil de proyectos dependientes
 Métricas ágiles y valor – VI encuentro ágil en Barcelona

También podría gustarte