Watch domina scrum con jira - metodología agile [2022] videos

Class Central is learner-supported. When you buy through links on our site, we may earn an affiliate commission.

Overview

Domina la herramienta JIRA y aprende a adaptarte al cambio para maximizar el valor aportado con tus proyectos Agile

What you'll learn:

  • En este programa aprenderá los conceptos de las metodologías ágiles y el enfoque SCRUM en detalle
  • Será capaz de gestionar proyectos con JIRA (creación de backlog, gestión del Sprint, control de la evolución del proyecto ágil)
  • Administrar roles y permisos utilizando JIRA
  • Entender la mecánica de trabajo con JIRA aplicable tanto a proyectos como procesos de cualquier departamento.
  • Consigue 3 PDUs para tu certificación PMP

¿Quieres convertirte en un experto en la herramienta JIRA y gestionar proyectos de metodología Agile?

-------------------------------------------------------

Escucha de otros alumnos por qué este es el curso de Scrum y JIRA MEJOR VALORADO en español:

"Muy buena explicación de las metodologías ágiles, poniendo especial foco en Scrum. Gran explicación de la herramienta Jira y todas sus funcionalidades. El curso transmite todos los aspectos necesarios para poner en práctica las metodologías ágiles en cualquier organización." -- Pedro Cañadas

"Me dio luz en la herramienta que utilizaré en un empleo nuevo y proyecto nuevo. El instructor mostro su amplio conocimiento de SCRUM con Jira Felicidades y gracias." -- Ángel Galicia Alamilla

"Excelente curso, el cual te da todas las herramientas necesarias para potenciar y gestionar a través de jira proyectos, epicas, historias de los usuarios y controlar metricas y tiempos. Muy bueno la verdad." -- Pablo Matharan

----------------------------------------------------------

Las metodologías ágiles surgen para dar respuesta a la creciente necesidad en cualquier proyecto de adaptarnos cada vez más rápido a los cambios en base a las necesidades del cliente.

En este curso aprenderás las herramientas necesarias para gestionar proyectos de manera exitosa a través del enfoque ágil SCRUM, revisando cada uno de los conceptos de este framework (pilares, artefactos, roles y eventos en SCRUM).

Por otra parte, se profundizará en el uso de JIRA, una herramienta de gestión de proyectos ágiles muy utilizada y que es altamente personalizable y adaptable a las necesidades de cada caso concreto.

El curso está estructurado en los siguientes bloques:

BLOQUE 1: METODOLOGÍAS ÁGILES Y ENFOQUE SCRUM

BLOQUE 2: INTRODUCCIÓN A JIRA

BLOQUE 3: LIDERANDO PROYECTOS ÁGILES CON JIRA

BLOQUE 4: ADMINISTRACIÓN DE JIRA

BLOQUE 5: CONCLUSIONES

En los próximos años habrá una fuerte demanda de perfiles especializados en gestión de proyectos con los conocimientos necesarios que sean capaces de adaptarse a diferentes situaciones y de dirigir satisfactoriamente equipos físicos y virtuales. El entorno actual en el que vivimos requiere de una metodología de la investigación, la adaptabilidad y la mejora continua, esto es algo que aprenderás en profundidad en este curso.

Por otra parte, tendrás una garantía de 30 días para asegurar que está 100% satisfecho con el material, mi objetivo es aportarte el máximo valor con todos estos conocimientos y si no es así siéntete libre de solicitar la devolución, aunque estoy seguro de que cumplirá tus expectativas.

Si quieres aprender una habilidad muy importante que podrá poner en práctica de inmediato y convertirte en el Scrum Master y gurú de JIRA tanto en su compañía como ámbito personal, este es tu curso.

Taught by

Ivan Pinar Domínguez

Reviews

4.5 rating at Udemy based on 1850 ratings

Start your review of Domina SCRUM con JIRA - Metodología Agile [2022]

Never Stop Learning.

Get personalized course recommendations, track subjects and courses with reminders, and more.

Metodologias Agiles (Scrum, Kanban, XP)

Watch domina scrum con jira - metodología agile [2022] videos

Por que existe esta Guía?

En este repositorio planeo crear una Guia de lo que son las metodologias Agiles y Como utilizarlas para el desarrollo de Software. Esto teniendo en cuenta el principio de que la mejor forma de aprender es enseñando espero que te sea de utilidad mis notas sobre estos conceptos para realizar de forma mas efectiva un proyecto.

Indice

  • Glosario.
  • Liderazgo en metodologias Agile.
  • Qué es Agile?.
  • Agile Manifesto
  • Los 12 Principios
  • Hacer Equipos
  • Negociación
  • Comunicación
  • Backlog
  • Personas
  • Estimar tiempos
  • Priorizar Tareas
  • Incremental Delivery
  • MVP
  • SCRUM
  • KANBAN
  • XP (Extreme Programming)
  • Herramientas

Algunas palabras importantes

A continuación te dejo algunas palabras que podrian generarte confusión al leer esta guía.

Agile: (Ágil) Nombre genérico de las metodologías de desarrollo

Iteraciones: Repeticiones de procesos con la finalidad de alcanzar una meta deseada. Estan formadas por una planeación esta se crea a partir de votaciones por ejemplo si estamos creando el registro de usuario de la pagina cual es la información que debemos pedirle al usuario para asi generar el mejor registro de usuario posible.

Sprint: Nombre con el que se le conoce a las iteraciones en SCRUM.

Framework: Conjunto estandarizado de conceptos, prácticas y criterios para enfocar un tipo de problemática particular

SCRUM: Framework de Agile para la administración en el desarrollo de productos.

KANBAN: Framework de flujo de trabajo para administración de desarrollo de productos.

Spike: Tipo de Sprint para realizar experimentos, investigación o documentación que pueda ser util para el proyecto.

Persona: Son los usuarios finales que interactuan con el producto.

Liderazgo e inteligencia emocional

Es importante saber conocer como primer concepto que en la metodologia Agile no existen lideres todo el equipo es lider esto es por que no nos interesa que nadie delege responsabilidades si no que se trabaje em conjunto para sacar adelante el proyecto esto implica entender que todos tenemos la responsabilidad de llevar al equipo adelante por lo que todos los miembros del equipo deben entender lo siguiente:

  • El equipo lo es todo no hay individulidades y no es una competencia interna. Somos expertos de diversas areas trabajando para conseguir un objetivo.
  • Mentalidad colectiva. Exitos y errores son responsabilidad de todos y no de alguien en especifico.
  • Comunicación. En las juntas diarias todos deben de explicar que hicieron ayer y que haran hoy (Para que surjan oportunidades de retroalimentación o ayuda para realizar esta tarea).

El modelo Tuckman es utilizado para saber como formar un equipo donde no existen lideres.

Es necesario comprender que para todos ser lideres y tener un equipo solido sus miembros deben tener inteligencia emocional esto es una soft-skill (habilidad blanda) ya que no se puede medir pero se sabra si sus miembros la poseen a medida que se desarrolle el proyecto.

Este concepto hace referencia a nuestra habilidad para poder relacionarnos con las demas personas y nuesdtro entorno a continuación presentare un cuadro para que puedas identificar puntos a desarrollar para tener una mayor inteligencia emocional ya que esta caracteristica es algo que algunas personas poseen de forma mas natural. Pero otras tienen que trabajar para desarrollarlo.

El tema de inteligencia emocional es un tema muy amplio e interesante por esto recomiendo que si te interesa saber mas sobre el tema leer los siguientes libros:

  • Cómo Ganar Amigos e Influir sobre las Personas de Dale Carnegie.

  • Los siete hábitos de la gente altamente efectiva de Stephen Covey.

Para saber como utilizar la inteligencia emocinal en un equipo dejare la siguiente tabla:

PersonalesSociales
Auto-Administración (Adaptabilidad, Motivación) Habilidades Sociales (Liderazgo, Motivación)
Auto-conocimiento (Conocimiento del ser, Apreciación) Conocimiento Social (Conocimiento de organización, Entorno)

Que es Agile?

Agile es una metodologia (framework para los mas puristas) de trabajo. Para tener una organización mas efectiva y mayor profesionalismo a la hora de desarrollar un proyecto en este caso lo oriento al software pero esto solo es por que es donde yo tengo mayor dominio pero facilmente puedes utilizar estos conocimientos en cualquier area esto es por que la metodología maneja conceptos muy interesantes para un trabajo mas fluido y profesional.

  • Esta metodología implica ser versatil y poder adaptarse a cambios en cualquier momento.

  • Ser Agil implica saber ser un lider que pueda manejar equipos de cualquier tamaño, experiencia o tipo.

  • Permite entender como priorizar esfuerzos.

Por lo tanto podemos entender Agil como una manera de administrar proyectos con las siguiente caracteristicas:

  • Entregas funcionales
  • Planear para minimizar problemas
  • Organizar el trabajo en iteraciones (ciclos de trabajo, en el caso de Scrum a estas iteraciones se les llama sprints)
  • Dominar la comunicación entre miembros del equipo, lideres y clientes (todos los que estan involucrados con el proyecto por lo que es ecencial identificarlos para poder hacer un buen trabajo).

Es vital que todos los miembros sepan que son un equipo con un fin común y todos trabajen para lograrlo.

Watch domina scrum con jira - metodología agile [2022] videos

Agile Manifesto (Manifiesto Agil)

El manifiesto ágil es un documento creado en 2001 que reúne principios y prácticas (procesos) para crear productos de software de una mejor manera.

El manifesto original lo puedes encontrar en http://agilemanifesto.org/ en este documento se nos presentan las siguientes primicias:

Descubrimos mejores formas de desarrollar software haciéndolo y ayudando a otras peronsas a hacerlo. Y se ha concluido que, si bien los elementos de la derecha son valorados, se valoran aún más los de la izquierda:

Individuos e interacciones sobre procesos y herramientas: confiar en las habilidades de cada miembro del equipo, valorar sus conocimientos y experiencia que pueda aportar, establecer una comunicación eficiente entre los miembros del equipo.

Software funcionando sobre documentación extensiva: pequeñas porciones de funcionalidad junto al código exclusivamente necesario para correr esas funcionalidades.

Colaboración con el cliente sobre negociación de contratos: una comunicación permanente y transparente con el cliente, en la cual el cliente transmitirá lo que espera del proyecto y el equipo siempre responderá con lo que se ha completado hasta el momento.

Respuesta ante el cambio sobre seguir un plan: mientras más pasa el tiempo, lo que se entrega al cliente cada vez es más grande, cambiando sólo lo necesario.

Los 12 Principios del Manifesto Agil

Los autores del manifesto Agil nos dan los siguientes principios para triunfar en un proyecto es importante recordar que todos los miembros del equipo deben seguir estos principios.

1.- Nuestra mayor prioridad es satisfacer al cliente mediante la entrega temprana y continua de software con valor.

2.- Aceptamos que los requisitos cambien, incluso en etapas tardías del desarrollo. Los procesos Ágiles aprovechan el cambio para proporcionar ventaja competitiva al cliente.

3.- Entregamos software funcional frecuentemente, entre dos semanas y dos meses, con preferencia al periodo de tiempo más corto posible.

4.- Los responsables de negocio y los desarrolladores trabajamos juntos de forma cotidiana durante todo el proyecto.

5.- Los proyectos se desarrollan en torno a individuos motivados. Hay que darles el entorno y el apoyo que necesitan, y confiarles la ejecución del trabajo.

6.-El método más eficiente y efectivo de comunicar información al equipo de desarrollo y entre sus miembros es la conversación cara a cara.

7.- El software funcionando es la medida principal de progreso.

8.- Los procesos Ágiles promueven el desarrollo sostenible. Los promotores, desarrolladores y usuarios debemos ser capaces de mantener un ritmo constante de forma indefinida.

9.- La atención continua a la excelencia técnica y al buen diseño mejora la Agilidad.

10.- La simplicidad, o el arte de maximizar la cantidad de trabajo no realizado, es esencial.

11.- Las mejores arquitecturas, requisitos y diseños emergen de equipos auto-organizados.

12.- A intervalos regulares el equipo reflexiona sobre cómo ser más efectivo para a continuación ajustar y perfeccionar su comportamiento en consecuencia.

Hacer un equipo

Creo que esta mas que claro que la metodología Agil esta muy centrada en un buen trabajo de equipo por esto nos muestra como debemos de armar un equipo abajo puedes ver un diagrama de como es la estructura.

Equipos y Roles

Equipo:

  • Diseñadores
  • Desarrolladores
  • QA (Quality assurance ejemplo testes)

Negocio:

  • Product Owner (Dueño del producto)
  • Usuarios
  • Stakeholders (terceras personas que tienen un interés (monetario o no) en una compañía u organización y pueden afectar o ser afectados por el negocio.)

Expertos:

  • Arquitectos
  • Técnicos

Con lo cual surgira la pregunta ¿Cómo podemos armar un buen equipo? esta pregunta se responde al definir Roles y Responsabilidades. Agile nos da los siguientes 9 pasos para crear nuestro equipo:

  1. Equipos multidisciplinarios: Garantizar que cada una de las habilidades sea cubierta y analizar qué y a quién necesito para cubrir cada una de esas áreas un ejemplo es si se crea una app movil necesitamos a un experto creando aplicaciones moviles y podemos definirlo mas como en que sistema IOS o Android.

  2. Reglas básicas y procesos internos: Se necesitan para tener una solución cuando se presente un conflicto estableciendo reglas basicas y procesos.

Las reglas por ejemplo pueden ser horarios, horas de reunión, quién es el experto en cada área, cómo se comunicara el equipo y por cuales canales como un chat, teléfono o en persona esto elimina muchos conflictos que pudieran presentarse.

Los procesos permitirán tener metas compartidas y un compromiso mayor como equipo.

  1. Combinar habilidades: Vamos a identificar gente integral ( Personas que se basan en los valores y características; Logra consciencia plena de lo que es como ser pensante debido a que piensa con claridad y orden la información que recibe y procesa, explica los hechos, da razón de lo que siente, de lo que hace, de lo que piensa. Además de razonar con orden y método, de utilizar el qué con claridad en sus ideas, es consciente de su motivación, del interés que le impulsa, de su afecto, de sus valores, del por qué piensa, siente y hace.) dentro del equipo con habilidades blandas, esto nos va permitir generar especialistas y posibles mentores para futuros proyectos.

  2. Entendimiento de principios: Lograr que todo el equipo tenga un buen entendimiento de valores, principios y de las mejores prácticas. Esto porque no todos los proyectos funcionan de la misma forma y si ya a trabajado con este tipo de metodología puede creer que se realizara de la misma forma pero no necesazriamente por esto es importante definir y aclarar todo esto desde un principio.

  3. Auto-organización: Vamos a crear una cultura de auto-organización para poder manejar la complejidad de un proyecto y así generar soluciones efectivas y mejorar el rendimiento del equipo.

  4. Ambiente seguro y experimental: Se debe crear un ambiente de seguridad que va en función de la comodidad y de alentar al equipo a crear experimentos o hacer un spike (iteración para experimentar, indagar o buscar nuevas tecnologías para integrarlas al proyecto). Se trata de fallar primero, pero de aprender para ser más versátiles al momento de integrar nuevas cosas al proyecto.

  5. Motivantes y desmotivantes:

Debemos identificar motivantes y desmotivantes de manera personal de cada miembro del equipo (personal) y grupal un equipo motivado sera mas efectivo. Este tipo de motivaciones dependen mucho de la persona por ejemplo Un reconocimiento público, un bono economico, una salida a cenar con todo el equipo.

Metas, planeación de iteraciones: También se pueden buscar metas generales, de cada uno de los elementos, y del equipo para tener algo en común por lo cual trabajar.

Retrospectivas: Qué funcionó, qué no funcionó, qué se podría mejorar y qué se podría intentar en la siguiente iteración. Y valorar si la siguiente iteración puede ser un spike.

Stand-Ups son juntas diarias en la que se va a conversar en qué fue lo que se hizo ayer, hoy y si tenemos algún problema para que algún miembro del equipo nos ayude.

  1. Comportamiento colaborativo: Tomas de decisiones grupales: Brainstorming, votaciones, juegos, tecnicas(Moscow), etc.

  2. Colocación: Ya formado el equipo y creado el compromiso. Pueden existir equipos locales y equipos remotos. Lo importante es que la comunicación sea eficiente y continua generalmente se busca crear equipos locales pero esto solo es por que la comunicación persona a persona es inmediata y esto presenta varias ventajas.

Negociacion

Siempre debe existir una colaboración constante entre todos los miembros del equipo pero existen casos en los que se presentan conflictos (entiendansen como diferencias de opinion acerca de actividades a realizar en historias de usuarios o formas de trabajar y no como problemas interpersonales entre miembros del equipo, para estos como se explico antes es necesario crear un equipo con inteligencia emocional.) por esto podemos definir las situaciones que se podrian presentar:

  • Problema: Se presenta cuando las personas no están descuerdo en algún punto
  • Desacuerdo: Se presenta cuando ambas partes justifican y defienden sus puntos
  • Concurso: Se presenta cuando una de las partes quiere imponer su propuesta, para esto incluyen una tercera o mas partes para definir quien esta en lo correcto
  • Cruzada: Ambas partes buscan imponer su propuesta a costa de un tercero o mas partes
  • Guerra: Es cuando las partes están dispuestas a todo para implantar su propuesta

Como Resolver estos conflictos

Soluciones:

  • Problema: Se resuelve con colaboración(ambas personas dialogan sobre sus propuestas y en conjunto buscan la mejor opción)
  • Desacuerdo: Apoyo(el equipo apoya a ambas partes y tratan de unirlas para llegar a un bien común)
  • Concurso: Compromiso (se alienta a las partes a tener un compromiso de unión entre ambas alternativas)
  • Cruzada: Diplomacia (Para atacar una cruzada hay que ser muy diplomático. Se aparta a los involucrados y se les da a entender que esa actitud no es la correcta, y se debe mostrar de forma clara que la propuesta de esta persona no es realista o no es posible de realizar por razones claras, dándole a entender que su propuesta no es viable en ese contexto)
  • Guerra: Vive con ello, cambia de opinión (en este punto el conflicto es muy difícil de solucionar, ya que pasamos por todos los puntos anteriores sin resolver el conflicto con éxito)

Una guerra en una metodología ágil causa muchos problemas tanto como retrasos como monetarios.

Si estas en un equipo ágil No quieres tener una guerra!!

Existen diversas metodologias que pueden utilizarse en este casos por ejemplo: La actividad de feedback efectivo de Martin Alaimo (http://www.martinalaimo.com/es/blog/feedback-efectivo) La nube de evaporación de conflictos del Dr. Eli Goldra (http://nodos.typepad.com/nodos_prime/files/toc_procesos_de_razonamiento_nde.pdf)

También este tema se toca en el libro Los siete hábitos de la gente altamente efectiva de Stephen Covey.

Comunicacion

Entre Roles

La comunicación es un basico para cualquier implementación de metodologías agiles, es la base del flujo de información por esto la comunicación siempre debe estar presente en cada uno de los proyectos de agile.

Para tener una comunicación efectiva hay que identificar a los miembros del equipo y sus roles para saber que tipo de información es prioritaria comunicarle, en las metodologías agiles tenemos por ejemplo:

El punto de vista administrativo (Stakeholders) que tiene interés en el proyecto, basados en 3 puntos fundamentales de la comunicación:

¿Estamos en tiempo?

Esto quiere decir que se mide en resultados, le importa saber que se ha terminado hasta el momento. Si estamos a tiempo, si no lo estamos, que es lo que falta, que es lo que se ha terminado, etc.

¿Estamos en costo?

Tenemos todavía cabida dentro del presupuesto. (Si o No)

¿Problemas?

Si se presentan problemas como se pueden solucionar, si hay un camino recorrido para buscar una solución eficiente o si se debe canalizar a otra parte para que se pueda encontrar dicha solución.

Punto de vista del cliente (Product Owner) Para esto existe una comunicación muy especifica se le conoce como Roadmap, basicamente es una descripción del valor del producto, es decir, es una descripción de lo que el cliente espera o que es lo que el cliente quiere hacer.

El equipo por otro lado le contesta con sus Historias de Usuario, que es la personificación de cada uno de estos requerimientos dando a entender que entienden lo que quiere hacer el dueño del producto esto si la historia cumple con el criterio de aceptación, es decir, esperar a que el cliente apruebe esa pequeña tarea para poder integrarla una vez que se haya hecho de manera correcta.

Backlog y comunicacion entre el equipo

El backlog es un contenedor lógico de las tareas que aún no se consideran en un proceso o estado activo para el equipo. Mientras mas arriba esten en el Backlog mas importancia tiene para su desarrollo. Esta es una herramienta muy importante para la comunicación efectiva por ejemplo tomemos en cuenta el punto anterior entre la comunicación Equipo - Cliente. El cliente nos dara un enunciado donde el equipo entiende que es lo que quiere el cliente luego especifican la tarea para poder integrarla una vez se acepte por parte del cliente si no se regresa al ciclo:

Watch domina scrum con jira - metodología agile [2022] videos

Un ejemplo de como utilizar esto es por ejemplo que el cliente quiere que agregemos una opción en la plataforma para agregar imagenes y nosotros le regresamos como seria esta parte del programa por ejemplo que exista un boton para añadir la imagen y esta se visualicen de forma cronologica en la plataforma. Pero el cliente nos dice que esto no es suficiente que además quiere que podamos introducir el nombre de la imagen, quien la subio, una descripción y un sistema para calificarlas. una ves que el equipo y el cliente estan en el mismo camino se hace un relese de esta tarea. Aprovechare para mostrar como es la comunicación en equipo y un ejemplo de la estructura de una historia.

Watch domina scrum con jira - metodología agile [2022] videos

Espero que con esto quede claro que es un Backlog y una historia ahora cabe mencionar que una historia esta ligada a un Wireframe que es una representación visual del producto, pero en relación a las interacciones de los usuarios y roles.

Watch domina scrum con jira - metodología agile [2022] videos

Personas

Persona es un personaje ficticio que usará nuestro producto.

El equipo está encargado de definir las características de ese usuario (nombre, edad, genero, si está casado o soltero, hijos, profesión, trabajo, su horario, pasatiempos, definanlo tanto como se pueda busquen una foto de alguien que nadie conosca e implantenle todo esto creenle una personalidad.

Definan sus meta y objetivo, que se verá resuelto con tu solución propuesta.

Cada que se tenga que tomar una desición del proyecto para incorporar a un Epic (funcionalidades extras que requieran varias iteraciones y que puedan dar un valor agregado al producto.), pueden utilizar a estas Personas para hacerlo, creando una simulación de como cambiariá su entorno. La incorporación de los Epics mejorara el producto y le dara mas valor al solucionar problemas que puedan tener los usuarios son detalles pero al final estos pequeños detalles suman mucho al producto.

Para trabajar las Historias de usuario con Epics vamos a dividir cada Epic en funcionalidades más pequeñas que podrán ir definiendo las historias de usuario que formarán dicho Epic.

Por qué es utili trabajar con personas?.

Estas permiten imaginarnos que estamos ayudando a alguien y estamos resolviendo un problema que tienen el cual no se habria pensado en el de no ser por lo definido del caracter de esta persona, Al simular personas estas se comportan como los posibles usuarios reales del producto y si no las creamos puede que se presenten problemas que no habiamos contemplado por ejemplo que a nosotros como programadores nos sea muy natural el uso del software que desarrollamos pero a una persona externa a este mundo le cueste mucho trabajo utilizar el programa. O un ejemplo mas especifico que la letra de nuestro programa sea muy pequeña y nuestra persona tiene problemas de visión por lo que poder ajustar la letra del programa le seria de mucha utilidad.

Recordemos que todo esto es para crear una mejor planificación y con ello crear mejores Historias de usuario segmentando mejor lo que se realizara. Existen tambien ya modelos para crear historias de usuario mas eficientes un ejemplo es el modelo INVEST:

  • Independent: Pueden realizarse en cualquier orden, no dependen unas de otras.
  • Negotiable: Son promesas de comunicación, no son contratos.
  • Valuable: Siempre debe dar valor al cliente, no debe crear historias técnicas.
  • Estimable: Si no se puede estimar es porque se debe conversar más aun.
  • Small : Pequeñas pero no demasiado.
  • Testable: Si no se puede probar, ¿Cómo puede saber que esté terminada?

Estimar tiempos

Con los conceptos anteriores bien entendidos surgira la pregunta ¿Cómo estimo el tiempo de las Historias de usuario? como se puede ver en la imagen numero 2 donde se muestra un ejemplo de como es una historia de usuario podemos ver que hay un tiempo estimado en horas para realizar esta tarea y un valor en puntos ¿que es todo esto y como se calcula?.

El valor en puntos es la dificultad que tiene cada tarea. Esto son asignados por un grupo, este grupo puede por ejemplo estar formado por los expertos en cada tema ellos se encargaran de asignar un valor numerico a cada historia de usuario el cual es la dificultad de la tarea. Existen diversas tecnicas para realizar esta estimación de puntos un ejemplo es usar la Sucesión de Fibonacci (https://es.wikipedia.org/wiki/Sucesi%C3%B3n_de_Fibonacci) como metodo para calificar la dificultad de las actividades por ejemplo la creación y normalización de la base de datos. Cada miembro dara un valor de la Sucesión de Fibonacci intentando que no sean numeros muy altos para darle su valor en puntos a la tarea una ves que todos los miembros expresen su opinión de cuantos puntos merece esta actividad se priorizan opiniones como la del experto en esta area obviamente se deben intercambiar opiniones de por que cada miembro dio tal valorización a esta tarea. Tambien por ejemplo en este mismo caso podemos imaginar que esta presente un experto en diseño de interfaces UX el cual no tiene conocimiento de bases de datos el puede decidir no participar en la valorización de esta tarea.

¿Qué pasa si la tarea es muy compleja y necesito asignarle un valor muy alto? Este caso es muy probable que se presente y por ejemplo se estima que se le debe de asignar un valor de 21 puntos (lo cual es muy alto). Puede trabajarse asi sin problemas pero en metodologías agiles se concidera una mejor idea analizar el por que esta tarea vale tanto y mejor dividirla en tareas mas pequeñas que tengan un menor valor. Esto es por que Agile utiliza mucho el principio "Divide Y Venceras".

El unico momento donde si es posible darle valores muy altos a la historia es cuando esta historia es un Epic ya que al ser detalles tan especificos suelen tener un alto nivel de dificultad.

Una ves este asignado el puntaje de una actividad normalmente las horas que se estiman para realizarla son los puntos asignados con 1 o 2 horas extras. Esto es por la capacidad de trabajo a que me refiero con esto supongamos que el tiempo establecido para la primera iteración son 2 semanas lo cual son 10 dias habiles de trabajo de estos 10 dias solo se trabajan realmente 8 hrs por lo que tendriamos 80 hrsy suponiendo que el equipo es de 4 personas tendriamos un ideal de 320 horas trabajadas en estos 10 dias pero la gente no trabaja como una maquina por lo que se reducen estas horas por ejemplo pensemos que no van a trabajar las 80 horas si no que de estas 80 horas solo trabajaran 60 por lo tanto el tiempo real es de 4x60=240 horas de trabajo claro que se establece un tiempo de trabajo esperado por ejemplo si nuestro tiempo real es de 240 hrs intentar que se trabajen 260.

Por esto varias herramientas ya tiene un monitoreo del tiempo emplado en una historia.

Priorizar Tareas

Un buen subtema sobre la estimación de tiempos es saber el por que es bueno priorizar tareas esto es por que agiliza las tareas y permite concentrarse en lo mas prioritario y no perder el tiempo con tareas que no son tan importantes existen varias formas de priorizar pero estas dependen de cada equipo y como decidan enfocar el proyecto por ejemplo:

  • Por el valor de la tarea: Suponiendo que tenemos tres tareas se elige la que mayor retorno de capital regrese al equipo conciderando cuanto retorna esta tarea y cuanto nos cuesta realizarla (Valor tarea - precio de fabricación) la que nos de el mayor valor neto es la que se trabajara.

  • Experiencia: Esta se basa en tener en el equipo gente con experiencia que al haber trabajado en proyectos similares puedan determinar una mejor ruta para realizar el proyecto. (También puede ser la experiencia del Product Owner)

  • Riesgos: Priorizar todos aquellos features que nuestro proyecto necesita como mínimo para funcionar.

Incremental Delivery

(Desarrollo productivo) Este es un concepto importante en las metodologías agiles y es entender que a medida que pase el tiempo el trabajo va a ir incrementando esto es por las iteraciones que se realizaran buscando lograr requerimientos tecnicos y no funcionales por que no en todas las iteraciones necesariamente realizaremos código esto por que puede haber iteraciones de investigación, entrenamiento, experimentación (spike), etc.

Por otra parte tambien se empezaran a realizar revisiones de funcionamiento, de codigo, de utilidad por parte del equipo y del Product Owner para que así el tiempo y el costo de nuestro producto sean lo mas bajas posibles. Por ejemplo en la revición del codigo este debe ser funcional aun que solo sea una pequeña parte.

Es por estos motivos que algunos equipos deciden tener iteraciones tematicas por ejemplo dedicar una iteracion al diseño solamente otra al desarrollo y otra a las pruebas pero esto al final sera como el equipo decida que se realicen las iteraciones para entregar el trabajo en el menor tiempo posible.

También un tema importante es que pasa si esta por terminar el tiempo de la iteración y no estan completas todas las historias de usuario, en estos casos se busca que las historias de usuario que no se completen sean las menos prioritarias que no dañen al proyecto ni al negocio.

Otra de las caracteristicas importantes del Incremental Delivery es estar siempre actualizados tecnicamente, esto se refiere a buscar la mejor tecnología para implementar al proyecto por esto es que hay iteraciones de investigación y de experimentación ya que asi se le da un mayor tiempo de vida a nuestro proyecto. Creo que es basico remarcar en este punto que la tecnología no solo sea de punta si no que sea estable y tenga futuro si no nuestros esfuerzos prodian ser en vano.

MVP (Minimum Valuable Product)

Ahora introduciremos el concepto de MVP basicamente son los features (caracteristicas) indispensables en el producto por lo que se refiere a saber que es lo minimo que tiene que tener nuestro producto para tener exito (desde el punto de vista del cliente generar ganancia) por lo que nos obliga a estudiar el producto como miembros del equipo y que lo conoscamos al 100%.

Por lo tanto el MVP es el conjunto de todos los features que debe de tener nuestro primer release. Ya que es una base fundamental de código.

Para saber mas acerca del MVP recomiendo leer el siguiente articulo: https://www.interaction-design.org/literature/article/minimum-viable-product-mvp-and-design-balancing-risk-to-gain-reward

Scrum

Es un framework de agile que es utilizado para simplificarnos la vida este tiene tres pilares fundamentales los cuales son:

  1. Transparencia: Toda la información que se maneja esta disponible para todos los miembros no hay secretos cualquier miembro puede pedir cualquier información y debe recibir siempre esta información.
  2. Inspección: Pueden presentarse terceras personas a inspeccionar el trabjo que se esta haciendo desde un punto de vista tecnico o administrativo.
  3. Adaptabilidad: A cambios, problemas o defectos que se puedan presentar.

Scrum es una certificación extra y tiene una gran comunidad y soporte para poder implementarse.

Watch domina scrum con jira - metodología agile [2022] videos

Roles en Scrum

  • Business (Negocio): Es el nombre que se le da a los Stakeholders que supervisan desde el punto de vista de tiempo y dinero.
  • Product Owner: Sigue manejandose de la misma forma.
  • SCRUM Master: Es aquel que cordina todas las juntas de Stand-Up, retrospectiva, planeación, etc. y que coordina al equipo. Las habilidades que requiere un SCRUM Master son: Ser una persona extrovertida. Tener desarrolladas habilidades intrapersonales. Poder comunicarse fluidamente con cada miembro del equipo.
  • SCRUM Team: Son los Diseñadores, Desarrolladores, QA

Como utilizar Scrum:

Watch domina scrum con jira - metodología agile [2022] videos

Reuniones

Como se puede observar en la imagen de arriba las reuniones son muy importantes por esto podemos clasificarlas en:

  • Reunión de planeación: Asisten el product owner, scrum master y scrum team. Se describen las prioridades al equipo, al final de la reunión se tienen dos cosas: una meta para el sprint que se realizara y un backlog del sprint.

  • Reunión de revisión: En cada sprint es requerido un incremento del producto (Agregarle valor). Así al final de cada sprint, el equipo muestra lo que se completó durante el sprint. Normalmente es un demo de un release o de una nueva característica. Participan el product owner, el scrum team, scrum master y todas las personas involucradas.

  • Reunión diaria: Cada día del sprint el equipo mantiene una reunión esta debe ser corta y precisa normalmente duran entre 15 y 20 minutos, en esta cada miembro del equipo responde tres preguntas: ¿Qué hiciste ayer?, ¿Qué vas a hacer hoy?, ¿Qué impedimentos tienes?. Asi pueden aparecer oportunidades de retroalimentación y ayuda.

  • Reunión de retrospectiva: Siempre existe oportunidad de mejora por esto esta es la última cosa para hacer en el sprint. En esta reunión se habla de qué cosas comenzar a hacer, qué dejar de hacer y cuáles continuar haciendo.

Valores de SCRUM:

Dentro de Scrum existen valores y codigos de etica que se deben de seguir para ser un miembro de la comunidad (Scrum members) estos son:

  1. Foco: Todos trabajamos por una meta en común, todos nos vamos a enfocar en realizar esas actividades para que la meta sea cumplida

  2. Valor: Como todos estanos trabajando en equipo nos ayudamos y compartimos conocimientos y recursos tanto humanos como tecnicos para afrontar los retos.

  3. Apertura: Estar abierto a criticas constructivas y a retroalimentación para poder mejorar como personas y miembros del equipo

  4. Compromiso: Todos trabajamos para alcanzar el exito.

  5. Respeto: Compartimos exitos y fracasos aprendemos a respetarnos y definir que los demas puedan valorar ese respeto.

Ejemplo de como utilizar SCRUM en la vida real:

KANBAN

Este framework esta mas enfocado a la visualización del flujo de trabajo quitando algunas de las metricas preestablecidas por las metodologias agile y las sustituye por algo mas visual. Esta metodologa fue introducida por la empresa Toyota, esta palabra biene del japones por lo que su traducción mas cercana al español es letrero por que basicamente de esta forma funciona Kanban.

Elimina conceptos como Epics y Subtareas. Las Iteraciiones se les llama ciclos de trabajo.

El flujo de trabajo es mas sencillo y visual por esto solo tenemos To Do, In progress y Done por lo que el tablero solo tiene tres columnas.

Se agrega el concepto de Work In Progress WIP ya que esta enfocado en reducir el trabajo, reduciendo el numero de historias In progress en el ciclo de trabajo. Por lo tanto al reducir los ciclos e historias de usuario los release van a ser mas amigables y pequeños, pero van a ser mas continuos y deben tener mejor calidad.

Watch domina scrum con jira - metodología agile [2022] videos

Principios

El trabajo debe de ser mas visual esto se pueden hacer con tarjetas fisicas que tengamos en un pizarron o compartirlas con el equipo.

Se debe limitar el Work In Progress por lo que no vamos a tener muchas historias de usuario para que asi todos los miembros del equipo puedan enfocarse en dichas historias.

El Flujon de trabajo es mas administrable ya que los ciclos de trabajo comienzan cundo se pasan a la historia de usuario y terminan una vez se a realizado un Peer-Review (o revisión de pares)

Peer-Review: Es una revision tanto de codigo como de pruebas que al final se presentan al Product Owner y se deciden si el criterio de aceptación es el apto para que esa historia sea completada.

Por lo que podemos ver este framework es mas sistematico que Agile o Scrum lo que nos lleva a tener historias de usuario mas completas en el menor tiempo posible esto nos lleva a la mejora continua ya que los ciclos de trabajo son mas cortos y las historias de usuario son mas manejables las mejoras nos hacen mejorar cada uno de los ciclos

Otros de los cambios que implementa esta metodología es que las juntas las realizaremos con las historias que se encuentren In Progress ya que en este ocurren cuatro fases que son el Analisis, Diseño, Desarrollo y Pruebas y aqui realizaremos estas reuniones por lo que trabajaremos con muy pocas historias de usuario para hacer este analisis (entre 1 y 2) por lo tanto cada una de estas fases generara un Peer-Review.

En base a las experiencia que se a adquirido en kanban se a llegado a la conclusion de que solamente se deben tener en cada In Progress:

  • 2 Historias de Analisis
  • 3 De Diseño
  • 4 De Desarrollo
  • 2 De Pruebas

Esto por el nivel de complejidad de cada una de las fases. Por lo que limita el WIP y es uno de los Principios mas importantes de Kanban

XP (Extreme Programming)

Este framework va mas enfocado al código y al desarrollo como su nombre lo indica esta enfocado en la programación extrema y se basa en los equipos que se enfocan en todo el desarrollo del producto y las pruebas hay 12 practicas de Extreme Programming las cuales son:

Watch domina scrum con jira - metodología agile [2022] videos

  1. Planeacion: Esta enfocado en como formar el equipo, quienes van a ser los expertos y definir roles y finalmente defir las iteraciones (una a dos semanas).
  2. Releases pequeños: Lleva al extremo todas las practicas de Agile el maximo pueden ser 2 semanas de iteración.
  3. Methapor. Eliminar todas las conversaciones tecnicas con el cliente. Pero seguimos trabajando de la mano con el y realizando las evaluaciones Por lo que se utilizan encambio analogias para eliminar toda la jerga tecnica que puede llegar a confundir al cliente ademas de que la mayoria de las veces resulta innecesaria.
  4. Diseño. Tomar todos los requerimientos del cliente y Entregar solo necesario para cumplir con esos lineamientos por esto el Diseño debe ser simple
  5. TDD(Test-Driven Development): Se deben diseñar primero las pruebas, despues el código para esas pruebas y finalmente todas las pruebas automaticas esto se refiere a Fail First (Fallar primero)
  6. Pair programming: Dos programadores utilizan solo una computadora para hacer el desarrollo normalmente se trabaja con una persona desarrollando el código y la otra generando algoritmos, la estructura del codigo, etc. y cada determinado tiempo cambian de lugar.
  7. Refactorizacion: Vamos a generar una refactorización de código (modificación del código fuente sin cambiar su comportamiento, se conoce informalmente por limpiar el código. Para mejorar su consistencia interna y su claridad. Los tests aseguran que la refactorización no cambia el comportamiento del código.)
  8. Codigo colectivo: Cualquier persona puede trabajara en cualquier porción de código
  9. Estrategia de integracion continua: Que toda la construcción del código se haga de manera automatica
  10. Marcha sostenible: Se va a tener un seguimiento mas intimo de cada uno de los desarrolladores por lo que todos los desarrolladores saben en que punto esta el proyecto y puedan saber que falta y que ya esta terminado
  11. Todo el equipo junto: No se pueden tener equipos remotos todos deben trabajar en el mismo espacio
  12. Estandares de codigo: Debemos pegarnos a los estandares de código de mayor calidad en el mercado.

Dentro de XP se presentan los siguientes Roles:

  • Coach: Coordina al equipo, organiza parejas para el Pair Programming, Trata con el Product Owner.
  • Product Owner:
  • Programador
  • Tester
  • Monitor: Experto técnico que realizara seguimiento (monitoreo) revisando el código, que todo funcione, que se esten utilizando las herramientas de manera correcta y realizara el reporte tecnico que se entrega al Coach para que este posterior mente lo discuta con el Product owner.

Este tipo de Metodologia trabaja con proyectos de codigo muy tecnicos por lo que genera una seguridad muy buena un codigo de muy alta calidad y un producto final excelente

Herramientas para Realizar Metodologias Agile

Por ultimo mencionare algunas herramientas que podemos utilizar para realizar esta forma de trabajo solo mencionare las herramientas mas no mostrare su uso ya que no tienden a ser muy complejas de utilizar y seguramente ya existan varios video tutoriales que puedan mostrarte como usarlas ademas pondre plataformas tanto libres como de pago:

  • Jira (https://es.atlassian.com/software/jira)
  • Trello (https://trello.com/)
  • Asana (https://asana.com/es/)
  • Rally (https://rally1.rallydev.com/slm/login.op)
  • Github (Github puede utilizarse también como una herramienta de metodologias Agile por esto es muy utilizada en el desarrollo de software)
  • Collabtive (http://collabtive.o-dyn.de/index.php)
  • Taiga (https://taiga.io/)

"Finalmente muchas gracias por leer esta guia espero que te sirva para realizar tus proyectos de software de una forma mas agradable y simple"

  • Alfonso Candiani Jaramillo

¿Qué es el Scrum en JIRA?

El tablero de Jira Scrum es la herramienta que une a los equipos en torno a objetivos únicos y promueve una entrega iterativa e incremental.

¿Qué diferencia hay entre Scrum y Agile?

Agile describe un conjunto de principios rectores que utilizan un enfoque iterativo para el desarrollo de proyectos o software. Por otro lado, Scrum es un conjunto específico de reglas que deben seguirse mientras se practica el desarrollo de software.

¿Qué es Scrum 2022?

SCRUM | Qué es, metodología, roles y conceptos ► Guía 2022. Scrum es una metodología de trabajo que permite a las empresas desarrollar sus proyectos de forma flexible, organizada y rápida; cumpliendo en todo momento con las necesidades y demandas de los clientes.

¿Qué herramientas se pueden utilizar con el método Scrum?

Los tres principales artefactos o herramientas Scrum son: el Product Backlog, Sprint Backlog y el Incremento.