Documentos de Académico
Documentos de Profesional
Documentos de Cultura
Requerimientos:
Tradicional vs. Caso de Uso vs. Historias de Usuario
Autor: Norberto Figuerola
Requisitos Tradicionales
Requisitos tradicionales suele
suelen ser considerados como las capacidades y las limitaciones
que tendr el sistema, el sistema es el trmino clave aqu.. Todos los buenos
requerimientos deben describir lo que el sistema puede
puede, o no puede hacer,, pero siempre
generalmente dichos requisitos que se centran intensamente en el sistema tienden a
restarle importancia a la interaccin del usuario o el contexto de los negocios relacionados
con el usuario o la empresa. Para ser justos, muchos de los requisitos tradicionales
proporcionan contexto para los negocios y lo
los usuarios, pero no suele ser el foco
principal, sino que el foco es el sistema
sistema.
La dificultad de que el sistema se
sea el enfoque, es que resulta necesario hacer
suposiciones sobre lo que el usuario desea. Los requisitos pueden
n ser la fuente de
registro para la operacin del sistema. En tal caso, la interaccin con el negocio o el
usuario, mientras el sistema est siendo desarrollado
desarrollado, se revierte a una serie de dolorosas
y negociadas solicitudes de cambio
cambio. El trabajo se convierte en una cuestin de darle
dar al
usuario exactamente lo que peda, que en absoluto puede ser lo que necesitaba.
Esto es lo que realmente hace que los requerimientos tradicionales se hagan difciles:
estn escritos desde la perspectiva del sistema. Adems, a menudo se escribe en el
contexto de un proceso lo que fuerza a un estricto control de cambios y un contrato
basado en los propios requisitos. La filosofa fomenta una estrecha comunicacin escrita
entre el analista de negocios y el equipo de desarrollo. Los cambios se vuelven una serie
de negociaciones muy controladas entre cliente y proveedor.
Segn el Instituto Internacional de Analistas de Negocios (IIBA), los buenos requisitos se
pueden describir a travs de los siguientes criterios:
Los requisitos tienen que estar completos. Deben ser lo ms completos posible,
sin partes abiertas u oportunidad para la interpretacin.
Los requisitos deben ser testeables. El desarrollador debe ser capaz de crear
una prueba o algn tipo de prueba de que el requisito se ha cumplido.
Los requisitos deben ser coherentes entre s, sin conflictos entre lo que se
especifica.
Los requisitos deben ser de diseo libre. Los requisitos de software deben
especificar lo que el sistema debe o no debe hacer, pero no en cmo el software
se encargar de la obligacin de que se cumpla, eso es diseo.
Los requisitos debern ser inequvocos. Declaraciones conceptualmente claras.
Nada que pueda ser interpretado de manera diferente de lo previsto.
Como se puede imaginar, los requisitos tradicionales buenos son difciles de escribir y son
un bien escaso. Si la creacin de un buen requerimiento es difcil, escribir un cuerpo
entero de los requerimientos completos y cerrados de un sistema es an ms difcil. El
nivel de detalle puede llevar a muchas interdependencias entre los requisitos que tienen
que ser analizados en la medida que van siendo desarrollados.
El usuario comprensiblemente se concentra en la interfaz y su interaccin con el sistema.
Un simple cambio en la interfaz de usuario puede crear un efecto domin a travs de los
requisitos. A menos que exista un buen mtodo de trazabilidad de requerimientos,
cualquier cambio de interfases o procesos de negocio pueden ser difciles de manejar.
Los requisitos tradicionales son especialmente delicados por cuanto el foco est en el
sistema, ms que ninguna interaccin del usuario.
de las interacciones. Los casos de uso por lo general tienen dos componentes principales:
Los diagramas de casos, que describen grficamente los actores y sus casos de uso, y el
texto del caso de uso propiamente dicho.
Los casos de uso se utilizan en reemplazo de los tradicionales principalmente en pesados
procesos orientados al control. El sistema se especifica a un alto nivel a travs de los
casos de uso y, a continuacin bloqueado con el control de cambios, dado el supuesto de
que los casos de uso capturan todo.
Tanto los casos de uso como los requisitos tradicionales se puede utilizar en desarrollos
giles de software, pero ambos se apoyan fuertemente en las especificaciones
documentadas del sistema, en lugar de la colaboracin tradicional de los mtodos giles.
Dado que no existe un enfoque integrado en la colaboracin, puede ser tentador ahondar
en una especificacin detallada en el caso de uso que se convierte en la fuente de
registro en lugar de un mecanismo de conversaciones.
Conclusin
En resumen las diferencias son: los requisitos tradicionales se centran en las operaciones
del sistema, con una tendencia a la especificacin detallada del sistema, los casos de uso
se centran en las interacciones entre el usuario y el sistema con una tendencia similar de
las especificaciones detalladas, y las historias de los usuarios se centran en el valor del
cliente con una fuerte intencin de fomentar la comunicacin.
Son las historias de usuario mejor que otros tipos de especificacin de requerimientos?
Depende de la situacin, pero en un ambiente de colaboracin, la experiencia indica que
claramente s. Las historias de usuarios no har que el proyecto sea gil, o la falta de
ellas har que sea difcil adquirir agilidad. Sin embargo, las historias de usuario alientan
un nmero de principios del Manifiesto gil:
D la bienvenida a los requisitos cambiantes, incluso a finales de desarrollo, como
ventaja competitiva del cliente.
Las personas de negocios y desarrolladores deben trabajar juntos diariamente a lo largo
del proyecto.
El mtodo ms eficiente y eficaz de transmitir informacin es la conversacin cara a
cara. .
Si usted tiene un ambiente decididamente no-gil, ayudan las historias de usuario? Una
vez ms, depende del equipo. Si un equipo est inmerso en un proceso de desarrollo en
cascada o pesados procesos iterativos y utiliza el enfoque de "pesada planificacin y
requerimientos up-front, es muy probable que influya en las historias de los usuarios,
convirtindolas en requisitos tradicionales. Las historias de usuarios son claramente un
poco vagas en cuanto a descripcin y se prestan a refinamientos sucesivos, la
planificacin y el diseo por adelantado no es donde radica su punto fuerte. La
especificacin detallada a menudo es la prctica en entornos de procesos controlados y
pesados, antes de que comience la codificacin de manera que los requisitos se puedan
utilizar para planificar el presupuesto y el proyecto entero.
Las historias de usuarios (cuando se utiliza segn lo previsto por los expertos como Cohn
y Cockburn) son demasiado sueltas de formato para prestarse a una documentacin
completa. Pero si, por el contrario, el equipo est abierto a la colaboracin con los
usuarios, el cliente, los analistas de negocios y los patrocinadores del proyecto y se puede
o se desea tolerar el cambio, las historias de los usuarios pueden ser el mtodo de
requisitos ms apropiado que adems ayuda a la colaboracin
Est prohibida la difusin, transmisin, modificacin, copia, reproduccin y/o distribucin total o parcial del presente Documento,
en cualquier forma y por cualquier medio, sin la previa autorizacin escrita del autor, encontrndose protegidos por las Leyes de
Derecho de Autor, Marcas, Lealtad Comercial, Bases de Datos y otras normas Asimismo, queda prohibido cualquier uso de los
Documentos o parte de los mismos con fines comerciales. La violacin de los derechos antes sealados puede acarrear condenas
civiles y/o penales establecidas en las normas precedentemente citadas. Se exigirn responsabilidades a los infractores por todas
las vas disponibles en derecho.
Fecha y lugar de publicacin: Buenos Aires, Febrero de 2012. Queda hecho el depsito que establece la Ley 11.723.