Logo DLSI

Tema 1 - Estructura de un equipo de desarrollo (DCA)

Curso 2023-2024

Conceptos clave

  • Eficiencia: En un equipo de desarrollo eficiente, cada uno sabe lo que tiene que hacer, no existe la sensación de que unos se entrometen en las tareas de los otros.

  • Ortogonalidad

    • Responsabilidades bien definidas

    • Mínimo solapamiento

  • La ortogonalidad depende del proyecto actual y del diseño del mismo que hagamos, también de las personas con las que contamos.

  • Un buen consejo para conseguir un sistema ortogonal es separar lo que es la infraestructura [1] de lo que es la aplicación. Cada componente de la infraestructura es gestionado por un subequipo o subgrupo.

  • A continuación asignamos las personas a los grupos. ¿Cómo medir la ortogonalidad del sistema?…​viendo cuánta gente (programadores) hay implicada en cada cambio que se pida del proyecto:

    • cuanto mayor sea el número, menos ortogonal será el sistema.

  • Procura que los integrantes de tu equipo lean y aprendan la guía de referencia del programador pragmático

Estructuras típicas

Estructura Jerárquica.
  • Propuesta por primera vez por Harlan Mills y descrita en 1972.

  • También se la conoce como la estructura del equipo quirúrgico

  • El núcleo consta de:

    • Programador o ingeniero en jefe. Planifica, coordina y revisa todas las actividades técnicas del equipo.

    • Personal técnico. Llevan a cabo las actividades de análisis y desarrollo.

    • Ingeniero de apoyo. Ayuda al ingeniero en jefe y puede sustituirle sin perdida de continuidad del proyecto.

  • Especialistas que ayudan al ingeniero en jefe. Por ejemplo, expertos en bases de datos, comunicaciones, etc.

  • Un bibliotecario de software (librarian) cataloga e indexa los módulos u objetos reutilizables.

Otras estructuras organizativas

  • Descentralizado democrático (DD).

    • No tiene un jefe permanente. Se nombran coordinadores de tareas a corto plazo y se sustituyen por otros para diferentes tareas.

    • Las decisiones y los enfoques se hacen por consenso.

    • La comunicación entre los miembros del equipo es horizontal.

  • Descentralizado controlado (DC).

    • Tiene un jefe definido que coordina tareas específicas y jefes secundarios que tienen responsabilidades sobre subtareas.

    • La solución de problemas es una actividad del grupo, pero la implementación de soluciones se reparte entre los subgrupos por el jefe de equipo.

    • La comunicación entre subgrupos e individuos es horizontal.

    • También hay comunicación vertical a lo largo de la jerarquía de control.

  • Centralizado controlado (CC).

    • El jefe de equipo se encarga de la solución de problemas a alto nivel y la coordinación interna del equipo.

    • La comunicación entre el jefe y los miembros del equipo es vertical.

A tener en cuenta

Podemos fijarnos en estos factores para estructurar un equipo de desarrollo:
  • Grado de dificultad del problema.

  • Nivel de modularidad permitido por el problema.

  • Ambito de vida del equipo que creamos.

  • Cantidad de líneas de código a escribir.

  • Grado de comunicación requerido para el proyecto.

  • Calidad y fiabilidad que debe tener el proyecto.

  • La fecha de entrega del producto.

Otros tipos de organización de equipos

Paradigma cerrado.

Jerarquía de autoridad similar al equipo Centralizado Controlado. Es útil en la producción de nuevo software similar a otro existente.

Paradigma aleatorio.

El equipo se estructura de manera libre en función de la iniciativa individual de los miembros. Útil cuando se requiere innovación. Puede presentar problemas cuando se requiere un rendimiento ordenado.

Paradigma abierto.

Estructura el equipo según una mezcla de los dos anteriores de manera que se consigan algunos de los controles asociados con el paradigma cerrado así como la innovación que aporta el paradigma aleatorio. Debe haber muy buena comunicación. Es adecuados para resolver problemas complejos, pero puede no ser tan eficiente como otras estructuras de equipos.

Paradigma sincronizado.

Las "partes" del problema nos sirven para organizar los miembros del equipo, los cuales suelen trabajar en estas partes del problema destacando la poca comunicación entre ellos.

Conceptos relacionados

  • No son objeto de estudio en esta asignatura.

  • Los estudiarás en otras asignaturas del grado.

  • Son el resultado de aplicar una organización determinada a nuestro equipo de desarrollo.

Dictador benevolente de por vida -BDFL- (I)

  • Es el nombre o título que se le otorga a determinadas personas en la comunidad de desarrolladores de software de código abierto.

  • Esto se puede hacer por varios factores:

    • por su personalidad

    • por su experiencia

    • por su relación con los demás integrantes del proyecto

  • Es importante que sea el originador del proyecto software.

  • Son los encargados de velar por el proyecto software que tutelan, de rodearse de las personas que consideren para abarcar todos los aspectos de ese proyecto.

  • El dictador benevolente puede delegar funciones y responsabilidades pero también puede tomar las decisiones finales en un momento determinado.

Dictador benevolente de por vida -BDFL- (II)

Algunos ejemplos concretos:

¿Dictador benevolente de por vida?

  • No tiene por qué.

  • Observa el caso de Guido van Rossum.

  • Hay más casos, ¿conoces Django, verdad? Qué te dice éste commmmit en su proyecto alojado en github?

  • Puedes ver algo más de esa historia aquí.

Aclaraciones

En ningún caso estas transparencias son la bibliografía de la asignatura.

1. BB.DD., Interfaz de usuario, lógica de negocio, comunicaciones, etc…​