Componente grupal:
a) Identificación del equipo
Nombre equipo: Mensajería LD
Módulo: B
Integrantes: David Ibáñez, Luis Pérez
Realización de entrega de rama Github FTR actualizada:



b) Muestra de alguna funcionalidad:
En el siguiente link se puede observar la funcionalidad de conexión de un cliente en el servidor.
https://youtu.be/OL6sbSIBdh4
c) Complejidad ciclomática total y evaluación de riesgo:
Complejidad ciclomática clase Cliente:

Complejidad ciclomática clase ClienteHilo:

Complejidad ciclomática clase Servidor:

La suma total de la complejidad de todas las clases suma un total de 55. Esto dividido por el total de funciones, nos entrega una complejidad ciclomática total de 4,2307. Por lo tanto podemos concluir nuestra evaluación de riesgo como un programa simple sin mucho riesgo.
d) Complejidad ciclomática por clases:
Complejidad ciclomática clase Cliente: La suma de la complejidad de esta clase corresponde a 15. Esto dividido por el total de funciones nos entrega un valor de 5. Por lo cual podemos concluir nuestra evaluación de riesgo como un programa simple sin mucho riesgo.
Complejidad ciclomática clase ClienteHilo: La suma de la complejidad de esta clase corresponde a 34. Esto dividido por el total de funciones nos entrega un valor de 4,8571. Por lo cual podemos concluir nuestra evaluación de riesgo como un programa simple sin mucho riesgo.
Complejidad ciclomática clase Servidor: La suma de la complejidad de esta clase corresponde a 8. Esto dividido por el total de funciones nos entrega un valor de 1,6. Por lo cual podemos concluir nuestra evaluación de riesgo como un programa simple sin mucho riesgo.
e) Evaluación acoplamiento y plan de mejora:

Creemos que la clase ClienteHilo, podría reemplazarse por una subdivición de dos clases, para así modularizar cada proceso de Thread en clases distintas, cada proceso con su respectiva clase asociada.
Componente individual:
f) Evaluación de cohesión
David Ibáñez:

Observamos como la función run, debido a sus características asociadas a override, no posee conexión con ninguna variable, esto debido a que dentro dicha función, es llamada la función lanzadorServidor.
Luis Pérez:

La función Cliente al ser una función constructor, no posee interacción con ninguna variable en este caso. Sin embargo, dentro de la función lanzadorCliente es llamada la función Cliente, estableciendo de esta forma relación entre ambas clases.