Beruflich Dokumente
Kultur Dokumente
Antonio Calero, Paco Castro, Hugo Mora, Miguel ngel Vicedo, David Garca Visin Innovadora de la Calidad del Producto Software REICIS Revista Espaola de Innovacin, Calidad e Ingeniera del Software, vol. 5, nm. 2, septiembre, 2009, pp. 49-55, Asociacin de Tcnicos de Informtica Espaa
Disponible en: http://www.redalyc.org/articulo.oa?id=92217153007
REICIS Revista Espaola de Innovacin, Calidad e Ingeniera del Software, ISSN (Versin electrnica): 1885-4486 reicis@ati.es Asociacin de Tcnicos de Informtica Espaa
Cmo citar?
Fascculo completo
Pgina de la revista
www.redalyc.org
Proyecto acadmico sin fines de lucro, desarrollado bajo la iniciativa de acceso abierto
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
Resumen
El desarrollo y la ingeniera del software se han venido complicando da a da en aras de conseguir desarrollos y soluciones cada vez ms completas, robustas y que respondan a los cada vez ms exigentes requisitos de las organizaciones. El proceso de aseguramiento de calidad tiene como misin principal garantizar todos los requisitos de calidad establecidos, no slo los que se refieren a un aspecto funcional, sino tambin a la fiabilidad, eficiencia, portabilidad, mantenimiento, Para ello, los controles de calidad no deben aplicarse nicamente al cdigo generado, sino que van mucho ms all, y deben recorrer elementos como las libreras de terceros, la arquitectura, la infraestructura tecnolgica (servidor de aplicaciones, base de datos, integracin), sin olvidar la seguridad, los procesos de construccin y la documentacin. Para cada uno de estos elementos definiremos un conjunto de actividades a realizar, una serie de herramientas de soporte y un conjunto de resultados a obtener. Palabras clave: calidad de software, aseguramiento de calidad, modelo de calidad, buenas prcticas, control de calidad.
49
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
1. Introduccin
El software es cada da mucho ms complejo, a todos los niveles. A nivel funcional, cada vez le pedimos que haga ms cosas, y ms importantes, y a nivel tcnico, la evolucin de las tecnologas implican la adaptacin de nuestro software en todo momento. Pero no slo se trata de complejidad sino tambin de criticidad. El software es cada vez ms crtico, automatizando aspectos ms importantes del negocio, y eso tiene como consecuencia que cualquier error o problema que ocasione el software ms impacto tendr sobre las organizaciones. La tendencia actual en las organizaciones es la centralizacin del software y el empleo cada vez mayor de aplicaciones con arquitectura web, esta caracterstica que permite usar las aplicaciones en cualquier momento y lugar obliga casi siempre a contemplar aspectos como la alta disponibilidad, tolerancia a fallos y el rendimiento. Esto requiere un control absoluto de todos los procesos implicados y adems a todos los niveles, ya que cualquier interaccin con el sistema podra desestabilizarlo. Lo habitual es que el proveedor de software garantice la calidad de su desarrollo, sin embargo esto no es suficiente, ya que hay que garantizar el correcto funcionamiento de todas las soluciones implantadas (infraestructura, comunicaciones, puestos, etc.).
Figura 1. Elementos que participan en la puesta en marcha de los sistemas de informacin actuales.
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
Balanceador de carga de las peticiones entre los servidores Servidores web de la capa frontal Servidores de autenticacin y validacin. Servidores de aplicaciones de la capa de negocio Servidores de base de datos Entornos de red y comunicaciones Servidores de backup y recuperacin Cualquier otro sistema de informacin externo con el que exista una dependencia
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
Una vez ms la solucin habitual es ampliar los recursos hardware. Esto mejorar el rendimiento puntualmente pero tarde o temprano los problemas volvern a aparecer. De nuevo la clave es optimizar los sistemas y mantener el software de base actualizados.
FUNCIONALIDAD
FIABILIDAD
USABILIDAD
EFICIENCIA
MANTENIMIENTO
PORTABILIDAD
Capacidad de ser analizado y cambiado Estabilidad Facilidad de prueba Conformidad de facilidad de mantenimiento
El trmino calidad se define como propiedad o conjunto de propiedades inherentes a una cosa, que permiten juzgar su valor. Por tanto, la calidad del software estar definida por el conjunto de propiedades del software que nos permitirn conocer si un software es
52
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
mejor o peor que otro, y concretamente estas propiedades vienen definidas por la norma ISO 9126 (estndar internacional para la evaluacin de la calidad del software [4]). El aseguramiento de la calidad del software conformar el conjunto de actividades planificadas y sistemticas necesarias para aportar la confianza en que el producto cumple con los requisitos de calidad establecidos. El proceso de aseguramiento de calidad debe garantizar no slo los aspectos que se refieren a cuestiones funcionales, sino tambin los que se refieren al resto de propiedades definidas (eficiencia, usabilidad, fiabilidad, portabilidad, etc.). El modelo de calidad presentado establece que los elementos a revisar van desde el ncleo con el cdigo fuente hasta la documentacin pasando por la infraestructura de ejecucin o los sistemas dependientes externos.
A continuacin resumimos algunas de las revisiones que forman parte de nuestro modelo de aseguramiento de la calidad: Cdigo fuente. Revisiones de convenciones de cdigo, de pruebas unitarias y cobertura, trazas, control de versiones, complejidad, etc. Libreras. Revisiones de licencias y versiones de libreras utilizadas, dependencias y solapamientos, uso de estndares, etc. Arquitectura. Revisiones del modelo de arquitectura, consistencia, escalabilidad, mantenibilidad y rendimiento, etc.
53
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
Infraestructura. Revisin de cachs y dependencias, revisiones de configuracin en los servidores de aplicaciones y servidores web, parametrizacin, ficheros de trazas, etc.
Base de datos. Uso de estndares, revisin de ndices, particionamiento, histricos, procesos en segundo plano, controles de versiones del modelo, etc. Seguridad. Seguridad en los puestos, seguridad en las integraciones y comunicaciones, planes de contingencia y continuidad, etc. Construccin. Revisin de los modelos de construccin de los desarrollos (integraciones, migraciones, etc.), automatizacin de reglas, empaquetado y ejecucin, etc.
Documentacin. Creacin de sitios web para los desarrollos, automatizacin y revisin de la documentacin, etc.
Un aspecto muy importante a tener en cuenta en todos los procesos de desarrollo de los productos es la integracin continua. La integracin continua tiene como finalidad prevenir errores muy comunes, adelantando todo aquello que pueda ser automatizado en el proceso de construccin de un producto. El objetivo es que con una frecuencia determinada se lleven a cabo esas tareas y en caso de detectar errores se proceda a su resolucin cuanto antes, evitando que los errores aparezcan el da de publicacin de una nueva versin. La integracin continua se basa en un motor de reglas que permite automatizar la ejecucin de todas esas tareas comunes y contribuye enormemente a mejorar la calidad del software.
3. Conclusiones
El aseguramiento de la calidad del software es una actividad continua durante todo el ciclo de vida de un sistema de informacin. El mbito es global, desde el cdigo fuente hasta la infraestructura, seguridad y documentacin, por lo que requiere un equipo tcnico multidisciplinar y herramientas de soporte especficas. No slo hemos de garantizar que el cdigo fuente es de calidad, sino tambin como este cdigo enlaza con las libreras de terceros, con la base de datos, con los servicios de integracin, etc. etc. Slo as podremos tener la confianza en que todos los requisitos de calidad se estn cumpliendo.
ISSN: 1885-4486 ATI, 2009 54
Revista Espaola de Innovacin, Calidad e Ingeniera del Software, Vol.5, No. 2, 2009
Referencias
[1] Casanova, J.C., Calero, A., Devesa, J., Arquitectura de Sistemas y Aplicaciones en Entornos Crticos: La experiencia de la Conselleria de Sanidad, IX Congreso Nacional de Informtica de la Salud, INFORSALUD 2006, Madrid. [2] Calero, A., Gmez, J., Gestin del Rendimiento y Calidad en Aplicaciones J2EE, X Congreso Nacional de Informtica de la Salud, INFORSALUD 2007, Madrid. [3] Calero, A., Casanova, J.C., Devesa, J., Entornos de Produccin Crticos en los Sistemas de Informacin Sanitarios. Monitorizacin. Diagnstico, IX Congreso Nacional de Informtica de la Salud, INFORSALUD 2006, Madrid. [4] ISO (International Organization for Standardization), Software Product Evaluation. Quality Characteristics and Guidelines for their Use. ISO/IEC Std 9126, ISO, 2001.
55