Download - Hexacta Booster Buenos Aires, Julio 2009 [logotipo del cliente] Una Empresa CMM - Nivel 4
Hexacta Booster
Buenos Aires, Julio 2009
[logotipo del cliente]
www.hexacta.com
Una Empresa CMM - Nivel 4
Una e
mpre
sa C
MM
- N
ivel 4
2
Agenda
8 Organización
8 Información general8 Objetivos del proyecto8 Descripción de problemas8 Trabajo realizado8 Arquitectura8 Demostración
Una e
mpre
sa C
MM
- N
ivel 4
3
Hexacta Booster
8 Automatizar tareas manuales repetitivas.
8 Promover estándares de desarrollo en Hexacta.
8 Proveer una solución para la automatización de nuevas tareas.
8 Agilizar tareas recurrentes.
8 Proveer una base de conocimiento.
8 Mejorar la calidad del desarrollo minimizando la cantidad de potenciales defectos debido a repetición manual de tareas.
8 Integración de “best-practices” de tecnologías.
Objetivos
Una e
mpre
sa C
MM
- N
ivel 4
4
Hexacta Booster
8 Booster es un “Quickstart Application ++”.
8 Posibilita un star up de proyecto rápido y sencillo.
8 Incorpora generación de código a partir del modelo de la aplicación.
8 Posee un sistema de templates unificado y colaborativo.
8 Utilización de metamodelos propios y de terceros para la generación de testing de diseño.
8 Desde el instante cero los servicios, integración de herramientas, tools de chequeo estático de código se encuentran operativas (estas tareas usualmente insumen las primeras 2 semanas de desarrollo).
Características generales
“QuickStart Application” = Generación de proyectos a partir de templates
Una e
mpre
sa C
MM
- N
ivel 4
Hexacta Booster
8 La aproximación Model-Driven Architecture define la funcionalidad de un sistema a partir de un modelo independiente de la plataforma (PIM), usando un lenguaje específico de dominio.
8 El PIM puede traducirse en uno mas modelos específicos de plataforma computable.
8 El objetivo de MDA es separar diseño de arquitectura.
8 Las modificaciones se realizan sobre el PIM, para luego regenerar el código.
8 En el proceso participan modelos intermedios.
MDA?
Una e
mpre
sa C
MM
- N
ivel 4
6
Automatización de tareas repetitivasTareas identificadas
Fuente:
startup de proyecto•Configuración de tecnologías•Integración de tecnologías siguiendo las best-practice de la comunidad•Tests de integración •Integración con IDE•Configuración y herramientas para el uso de métricas
persistencia•DAOS y Orm Mappings
servicio•Servicios, transaccionalidad, seguridad, spring beans.
vista•CRUD Tables, Spring beans, Testing.
Una e
mpre
sa C
MM
- N
ivel 4
Templates de proyecto•Maven Archetypes
Generación de Código •Modelar objetos de negocio primero.
•Introspección del modelo
•Generar código
Usabilidad•Maven 2 Plug-in•Eclipse Plug-in •Visual Studio Plug-in
7
Automatización de tareas repetitivasSolución
Una e
mpre
sa C
MM
- N
ivel 4
Creación de proyectos
8
Maven Archetype Plugin
El Archetype Plugin permite al usuario crear un proyecto Maven 2 a partir de un template de proyecto llamado arquetipo.
Automatiza la creación de templates de proyecto a partir de proyectos existentes (archetype:create-from-project).
Es posible compartir templates mediante repositorios (característica “network-ready” de Maven).
Estandarización de la estructura de directorio:
Una e
mpre
sa C
MM
- N
ivel 4
Creación de proyectos
9
Arquetipos
• Clasificación segun tecnología.
• Arquetipos HxBooster:
Hibernate-Spring-Tapestry
JpaHibernate-Spring-Tapestry
Modular-Hibernate-Spring-Struts2
Modular-JpaHibernate-Spring-Struts2
Modular-NHibernate
Una e
mpre
sa C
MM
- N
ivel 4
Creación de proyectos
10
Arquetipo Hibernate-Spring-Struts2
Tests de integración mínima.
Dependencias de tecnologías del proyecto y configuración de plugins: Reportes (checkstyle, cobertura, pmd …). Deploy (Maven Cargo). WebTest (Test de navegabilidad).
Estructura modular.
Una e
mpre
sa C
MM
- N
ivel 4
Creación de proyectos
11
Arquitectura de serviciosServicios de aplicacion
Servicios de Sistema
Errores Seguridad Transaccionalidad
1. Servicio de la aplicacion.
(A partir de una entidad)
2. Servicio de la aplicacion.
(A partir de una entidad)
N. Servicio de la aplicacion.
(A partir de una entidad)
• La arquitectura de servicios se compone de una cadena de interceptores o proxies del “servicio entidad”, donde los interceptores son, el servicio de seguridad, manejo de errores y transacciones.
• El servicio de aplicación generado a partir de una entidad no tendrá que implementar cuestiones referentes a los servicios de sistema citados.
Una e
mpre
sa C
MM
- N
ivel 4
Booster Code Generator
12
<<Engine>>Booster
ConfigurationProject
Configuration
Engine de generación
Configuration: modela la configuracion actual de generación.
ProjectConfiguration: modela configuración de tecnologías del proyecto.
• BoosterCodeGenerator contiene la lógica de generación para código de persistencia, servicios y vista. Es el motor de generación de HxBooster.
• La generaciones se realizan a partir de un meta modelo inferido del modelo original de la aplicación.
Una e
mpre
sa C
MM
- N
ivel 4
Booster Code Generator
13
Meta-Modelos
• Un modelo es una abstracción de un fenómeno en el mundo real; un metamodelo es otra abstracción que destaca ciertas propiedades del mismo modelo.
• Mapping Generator es un generador de archivos de mapeo para una tecnología de ORM específica.
Java Model
Net Model
Meta Model Builder
Meta Model ORM
Model Builder
DAO Generator
Service Generator
View Generator
ORM Model
Mapping Generator
• ORM Model es un modelo que mantiene propiedades necesarias para construir mappings de frameworks ORM.
Una e
mpre
sa C
MM
- N
ivel 4
Booster Code Generator
14
Generaciones soportadas
Proyectos Java Persistencia:
Hibernate MappingsHibernate DAOSSpring DAOSDAOS tests (Junit 3/4)Spring beans
Servicio:Servicios DTO interface (DynaDTO)Servicios tests (Junit 3/4)Spring beans
Vista:CRUD tables (Struts 2)Struts 2 ActionsActions configurationSpring beans
Proyectos .Net
PersistenciaNhibernate MappingsNhibernate DAOSDAOS tests
Una e
mpre
sa C
MM
- N
ivel 4
Clientes Booster
15
Evolución
• Como primera instancia BoosterCodeGenerator se lo visualiza como aplicación de consola.
• Como la creación de proyectos a partir archetypes desencadena en proyectos M2, y dado que el framework de plugins M2 se adapta correctamente para el desarrollo de un cliente booster se implementa maven-booster-plugin.
• En busca de mayor usabilidad, se desarrolla un booster-plugin
para Eclipse y un prototipo para Visual Studio.
<<Cliente>>Maven2
<<Cliente>>Plugin Eclipse
<<Cliente>>Plugin Visual
Studio
<<Cliente>>Command-Line
Custom
<<Engine>>Booster
Una e
mpre
sa C
MM
- N
ivel 4
Cliente Maven 2
16
Maven-booster-plugin
• Un plugin Maven provee un conjunto de metas que pueden ser ejecutadas usando la siguiente sintáxis:
mvn [plugin-name]:[goal-name]
• Generación de proyectos simplificada:
mvn booster:generate-HSS -DprojectName=NAME [-DgroupId=GROUPID] [-Dversion=VERSION]
• Generación de DAOS:
I. mvn booster:gen-all-dao
II. mvn booster:gen-dao
-Dentity=ENTITY
[-Dattributes=className1:attrib1,..,attribN;...;classNameN:attrib1,...,attribN]
[-DmappingHierarchy=entitybranch/allhierarchy]
Una e
mpre
sa C
MM
- N
ivel 4
Cliente Eclipse
17
eclipse-booster-plugin
Motivaciones:
• Maven resulta ideal para generar nuevos proyectos a partir de archetypes, pero carece de usabilidad cuando debemos realizar generaciones a partir de una entidad.
• Los templates de BoosterCodeGenerator son fijos y no se provee un mecanismo para editar o reemplazar templates.
• El entorno de desarrollo de plug-in para eclipse provee un conjunto de apis-plugins que posibilitarían la automatización de nuevas tareas.
• Reutilización de wizards y plugins.
Una e
mpre
sa C
MM
- N
ivel 4
eclipse-booster-plugin
18
Templetizador de texto
• Integrado en IDE:
• A partir de una selección de texto es posible crear un template en el momento.
• Aplicación y búsqueda ágil de templates. • Herramienta colaborativa:
• Permite exportar/importar templates.
• Configurable con repositorio remoto.
• Reutiliza componentes de eclipse.
• Aplicable sobre cualquier editor de eclipse.
• Posibilita modificar templates de hxBooster (Meta-Template System).
Una e
mpre
sa C
MM
- N
ivel 4
eclipse-booster-plugin
19
Meta Template System
Meta Template System
Repository
Booster Code Generator
eclipse-booster-plugin
• Meta-template System es engine de templates de HxBooster.
• El sistema de templates puede configurase con distintos tipos de repositorios.
• Diferentes instancias de Meta-Template System podrían configurarse para que utilicen un repositorio común.
Una e
mpre
sa C
MM
- N
ivel 4
Testing de diseño
20
Cobertura de RuntimeException
• Puede ocurrir la situación donde un desarrollador elimine una sentencia que levanta una RuntimeException.
• Esta funcionalidad permite verificar si toda RuntimeException que se levanta en el proyecto posee un test de excepción.
• Utiliza eclipse search api.
• Una vez detectados los métodos no cubiertos, se inicia un wizard de refactoring el cual permite introducir en los TestCase los esqueletos de test de excepción.
Una e
mpre
sa C
MM
- N
ivel 4
Funcionalidades adicionales
21
• Generación de métodos recurrentes:
• Integración de Commons-Eclipse.
• Permite generacion automática de los siguientes métodos usando builders de commons-lang:
toString()hashcode()equals(Object)compareTo(Object)
• Generación de llamadas a métodos privados:
• Cuando queremos testear un método privado, o bien un test involucra una llamada a método privado.
• Resuelve la problemática de armado de parámetros formales y actuales para el código de llamada a métodos privados vía reflection.
Una e
mpre
sa C
MM
- N
ivel 4
22
Hexacta Booster
Desarrolladores:
Jesica Marquez
Virginia Martz
Gisela Rivarola
Federico Martín Rodriguez
Lucas Tenconi
General
www.hexacta.com
Arguibel 2860Capital Federal (C1426DKB) tel: 54+11+4779 6400
ARGENTINA
Cardoso de Melo 1470 - 8Vila Olimpia | San PabloCEP (04548004) tel: 55+11+3045 2193
BRASIL