stringtranslate.com

Trazabilidad de requisitos

La trazabilidad de requisitos es una subdisciplina de la gestión de requisitos dentro del desarrollo de software y la ingeniería de sistemas . La trazabilidad como término general se define en el Vocabulario de Ingeniería de Software y Sistemas del IEEE [1] como (1) el grado en el que se puede establecer una relación entre dos o más productos del proceso de desarrollo, especialmente productos que tienen un predecesor-sucesor o primario. -relación de subordinación entre sí; [2] (2) la identificación y documentación de rutas de derivación (hacia arriba) y rutas de asignación o flujo descendente (hacia abajo) de productos de trabajo en la jerarquía de productos de trabajo; [3] (3) el grado en que cada elemento de un producto de desarrollo de software establece su razón de existir; y (4) asociación discernible entre dos o más entidades lógicas, como requisitos, elementos del sistema, verificaciones o tareas.

La trazabilidad de requisitos en particular, se define como "la capacidad de describir y seguir la vida de un requisito tanto hacia adelante como hacia atrás (es decir, desde sus orígenes, a través de su desarrollo y especificación, hasta su posterior implementación y uso, y a través de períodos). de refinamiento e iteración continuos en cualquiera de estas fases)". [4] [5] En el campo de la ingeniería de requisitos, la trazabilidad consiste en comprender cómo los requisitos de alto nivel (objetivos, metas, aspiraciones, expectativas, necesidades comerciales) se transforman en requisitos de bajo nivel listos para el desarrollo. Por lo tanto, se ocupa principalmente de satisfacer las relaciones entre capas de información (también conocidas como artefactos). [6] Sin embargo, la trazabilidad puede documentar relaciones entre muchos tipos de artefactos de desarrollo, como requisitos, declaraciones de especificaciones, diseños, pruebas, modelos y componentes desarrollados. [7] Por ejemplo, es una práctica común capturar relaciones de verificación para demostrar que un requisito es verificado por un determinado artefacto de prueba.

La trazabilidad es especialmente relevante cuando se desarrollan sistemas críticos para la seguridad y, por lo tanto, está prescrita por directrices de seguridad , como DO178C , ISO 26262 e IEC61508 . Un requisito común de estas directrices es que los requisitos críticos deben verificarse y que esta verificación debe demostrarse mediante la trazabilidad. [8]

Seguimiento hacia y más allá de los requisitos

Trazabilidad de requisitos previos . [4] Los requisitos provienen de diferentes fuentes, como la persona de negocios que solicita el producto, el gerente de marketing y el usuario real. Todas estas personas tienen diferentes requisitos del producto. Al utilizar la trazabilidad de requisitos, se puede rastrear una característica implementada hasta la persona o grupo que la deseaba durante la obtención de requisitos . Esto se puede utilizar durante el proceso de desarrollo para priorizar el requisito y determinar qué tan valioso es el requisito para un usuario específico. También se puede utilizar después de la implementación para ver por qué ciertas funciones no utilizadas encontradas durante los estudios de usuarios fueron necesarias en primer lugar.

Trazabilidad post-requisitos . [4] No sólo se deben rastrear los requisitos en sí, sino también la relación de los requisitos con todos los artefactos asociados con ellos, como modelos, resultados de análisis, casos de prueba, procedimientos de prueba, resultados de pruebas y documentación de todo tipo. Incluso se debe poder rastrear a las personas y grupos de usuarios asociados con los requisitos. Los requisitos se materializan en artefactos de diseño, implementación y, finalmente, se verifican. Los artefactos vinculados a las últimas etapas también deben rastrearse hasta los requisitos. Esto normalmente se hace a través de una matriz de trazabilidad de requisitos .

Establecer una trazabilidad más allá de los requisitos en los artefactos de diseño, implementación y verificación puede resultar difícil. [9] Al implementar requisitos de software, por ejemplo, los requisitos pueden estar en una herramienta de gestión de requisitos , mientras que los artefactos de diseño pueden estar en una herramienta de diseño. Además, los artefactos de implementación probablemente estarán en forma de archivos fuente, cuyos vínculos se pueden establecer de diversas maneras en distintos ámbitos. Artefactos de verificación como los generados por pruebas internas o herramientas de verificación formales.

La integración de repositorios o pilas de herramientas puede presentar un desafío importante para mantener la trazabilidad en un sistema dinámico.

Uso de información de trazabilidad

El uso de la trazabilidad, especialmente cuando se rastrea más allá de los requisitos hasta todos los artefactos ubicados en la cadena de herramientas, puede traer varios beneficios: [10] [11]

En [12] se ofrece una descripción más completa de las actividades de desarrollo respaldadas por la trazabilidad y su relevancia.

Uso práctico de la información de trazabilidad.

Amplios estudios documentan la eficacia, pero también las dificultades, de capturar información de trazabilidad:

Visualización de información de trazabilidad.

Uno de los objetivos de la trazabilidad es visualizar la relación entre los artefactos. A medida que aumenta el número y la complejidad de los enlaces de seguimiento, se necesitan técnicas para la visualización de la trazabilidad. Una visualización puede incluir información sobre los artefactos (por ejemplo, tipo de artefacto, metadatos, atributos) y enlaces (por ejemplo, tipo de enlace, metadatos, intensidad del enlace). [dieciséis]

Las visualizaciones comunes para la información de trazabilidad son matrices , gráficos , listas e hipervínculos .

Las visualizaciones se pueden combinar para superar sus limitaciones específicas.

Realización técnica

Trazabilidad manual

La trazabilidad se logra mediante la captura de rastros, ya sea de forma totalmente manual o con herramientas, por ejemplo, como una hoja de cálculo en Microsoft Excel . Aunque se aplica ampliamente, este proceso es engorroso, propenso a errores y, a menudo, conduce a información de trazabilidad de calidad insuficiente debido a las diversas herramientas de desarrollo involucradas y al número típicamente muy alto de artefactos que deben rastrearse. [18]

Trazabilidad asistida por herramientas

La trazabilidad respaldada por herramientas requiere que la información de desarrollo que se distribuye a lo largo de toda una cadena de herramientas de desarrollo esté homogeneizada y agregada. Existen los siguientes enfoques para alcanzar este estado:

Homogeneización del entorno de herramientas de software a través de una herramienta ALM : las cadenas de herramientas ALM cubren el ciclo de vida del desarrollo de software y gestionan todos los artefactos del proceso de desarrollo de software. Muchas empresas han elegido el mejor enfoque con gestión de tareas, gestión de códigos y numerosas herramientas de automatización de pruebas. Las empresas que eligen el mejor enfoque resuelven el desafío de la trazabilidad con herramientas de gestión de requisitos (RM) que proporcionan un modelo de trazabilidad completo e integraciones para las mejores herramientas. Una única herramienta ALM que cubra requisitos, análisis de riesgos, diseño de sistemas, gestión de tareas, repositorios de código, integración, pruebas y más es un equilibrio clásico entre las mejores capacidades y una plataforma común con funciones más limitadas.

Homogeneización de datos a través de requisitos sustitutos : las herramientas de gestión de requisitos (RM) permiten almacenar, organizar y gestionar todos los requisitos de las especificaciones de un sistema y, por lo general, organizarlos en un árbol de especificaciones que vincula cada requisito con su requisito principal en la especificación superior. Las funciones de análisis típicas basadas en información de trazabilidad registrada son, por ejemplo, comprobaciones de integridad, es decir, si todos los requisitos del nivel del sistema bajan al nivel del equipo (con o sin modificación), evaluación de las desviaciones de los requisitos en todos los niveles y presentación del estado de calificación. Para garantizar la trazabilidad de tipos de artefactos más allá de los requisitos, las herramientas de RM a menudo permiten importar otros artefactos como requisitos sustitutos que luego se pueden rastrear con los métodos de seguimiento de requisitos de la herramienta. La desventaja de este enfoque es que se necesitan diferentes adaptadores o convertidores para los diferentes tipos de artefactos que deben tener una versión y un formato de datos consistentes. A diferencia de las herramientas ALM, esta coherencia la debe realizar uno mismo.

Homogeneización de datos a través de una herramienta de trazabilidad dedicada : el concepto básico de herramientas de trazabilidad dedicadas consta de tres pasos esenciales:

El enfoque reúne las ventajas de los enfoques antes mencionados: cubre todas las herramientas y artefactos en un enfoque holístico, homogeneiza los datos y evita el riesgo de inconsistencias causadas por sustitutos obsoletos. La desventaja es que este enfoque implica la extensión de una cadena de herramientas mediante otra herramienta (de trazabilidad).

Herramientas de trazabilidad

En muchos proyectos, la gente utiliza herramientas ofimáticas como hojas de cálculo para gestionar la trazabilidad. Estas herramientas son propensas a errores cuando tienes cientos de requisitos y varios usuarios trabajando en un proyecto. Podrás utilizar herramientas de trazabilidad especializadas para un control efectivo de tus proyectos.

Ver también

Referencias

  1. ^ Ingeniería de sistemas y software - Vocabulario . ISO/IEC/IEEE 24765:2010(E). 2010-12-01. págs. 1–418. doi :10.1109/IEEESTD.2010.5733835. ISBN 978-0-7381-6205-8.
  2. ^ Guía IEEE para desarrollar especificaciones de requisitos del sistema . Edición de 1998 IEEE STD 1233. 1998-12-01. págs. 1–36. doi :10.1109/IEEESTD.1998.88826. ISBN 978-0-7381-1723-2.
  3. ^ Guía IEEE para tecnologías de la información - Definición del sistema - Documento de concepto de operaciones (ConOps) . IEEE STD 1362-1998. 1998-12-01. págs. 1–24. doi :10.1109/IEEESTD.1998.89424. ISBN 978-0-7381-1407-1.
  4. ^ abc Gotel, OCZ; Finkelstein, CW (abril de 1994). "Un análisis del problema de la trazabilidad de requisitos". Actas de la Conferencia Internacional IEEE sobre Ingeniería de Requisitos . págs. 94-101. CiteSeerX 10.1.1.201.7137 . doi :10.1109/icre.1994.292398. ISBN  978-0-8186-5480-0. S2CID  5870868.
  5. ^ Gotel, Orleña; Cleland-Huang, Jane ; Hayes, Jane Huffman; Zisman, Andrea; Egyed, Alejandro; Grünbacher, Paul; Dekhtyar, Alex; Antoniol, Giuliano; Maletic, Jonathan (1 de enero de 2012). "Fundamentos de la trazabilidad". En Cleland-Huang, Jane; Gotel, Orleña; Zisman, Andrea (eds.). Trazabilidad de Software y Sistemas . Springer Londres. págs. 3–22. doi :10.1007/978-1-4471-2239-5_1. ISBN 9781447122388.
  6. ^ Casco, Isabel; Ken Jackson; Jeremy Dick (2005). Ingeniería de requisitos (Segunda ed.). Saltador. págs. 9–13, 131–151. ISBN 978-1-85233-879-4.
  7. ^ Pinheiro FAC y Goguen JA, "Una herramienta orientada a objetos para requisitos de seguimiento", IEEE Software 1996, 13(2), págs. 52-64
  8. ^ ab Mäder, P.; Jones, PL; Zhang, Y.; Cleland-Huang, J. (1 de mayo de 2013). "Trazabilidad estratégica para proyectos críticos para la seguridad". Software IEEE . 30 (3): 58–66. doi :10.1109/MS.2013.60. ISSN  0740-7459. S2CID  16905456.
  9. ^ Li, Yin; Juan Li; Ye Yang; Mingshu Li (2008). Trazabilidad centrada en los requisitos para el análisis del impacto del cambio: un estudio de caso . Springer Berlín/Heidelberg. págs. 100-111. ISBN 978-3-540-79587-2.
  10. ^ Wiegers, Karl (2013). "Trazabilidad de requisitos: eslabones de la cadena de requisitos, parte 1". jama . Consultado el 14 de diciembre de 2016 .
  11. ^ Wiegers, K.; Beatty, J. (2013). Requisitos de Software . Prensa de Microsoft.
  12. ^ Caldo, Elke; Mäder, Patrick; Philippow, Ilka (8 de abril de 2013). "Una encuesta sobre escenarios de uso para la trazabilidad de requisitos en la práctica". En Doerr, Jörg; Opdahl, Andreas L. (eds.). Ingeniería de requisitos: base para la calidad del software . Apuntes de conferencias sobre informática. vol. 7830. Springer Berlín Heidelberg. págs. 158-173. CiteSeerX 10.1.1.659.3972 . doi :10.1007/978-3-642-37422-7_12. ISBN  9783642374210.
  13. ^ Señor, Patrick; Egyed, Alejandro (1 de abril de 2015). "¿Se benefician los desarrolladores de la trazabilidad de requisitos al desarrollar y mantener un sistema de software?". Ingeniería de software empírica . 20 (2): 413–441. doi :10.1007/s10664-014-9314-z. ISSN  1382-3256. S2CID  2514618.
  14. ^ Rempel, Patricio; Mäder, Patrick (1 de enero de 2016). "Prevención de defectos: el impacto de la integridad de la trazabilidad de los requisitos en la calidad del software". Transacciones IEEE sobre ingeniería de software . PP (99): 777–797. doi :10.1109/TSE.2016.2622264. ISSN  0098-5589. S2CID  1959772.
  15. ^ "open-DO | Hacia un marco cooperativo y abierto para el desarrollo de software certificable". www.open-do.org . Consultado el 15 de abril de 2017 .
  16. ^ abcdef Li, Y.; Maalej, W. (2012). ¿Qué visualización de trazabilidad es adecuada en este contexto? Un estudio comparativo . Saltador. págs. 194-210.
  17. ^ Lerche, Félix (2019). "5 RAZONES POR LAS QUE UNA MATRIZ DE TRAZABILIDAD DE REQUISITOS NO ES SUFICIENTE".
  18. ^ Kannenberg, Andrés; Saiedian, Hossein (2009). "Por qué la trazabilidad de los requisitos de software sigue siendo un desafío" (PDF) . Revista CrossTalk: la revista de ingeniería de software de defensa .