XUnit 1.0.2 y Resharper 4.1
Cuanto se ha cambiado NHibernate desde 1.2.1 hasta 2.0 GA?
Patrick Smacchia me envia este link donde analiza NHibernate con NDepend.
Quiero que aprecien el análisis que realizó con esta herramienta, donde el que considero más importante son el análisis de los cambios realizados. En el enlace vean el gráfico con las zonas pintadas de azul, y van a ver cuantos cambios se hicieron
NHibernate 2.0: Changes Overview
Resultados en aplicaciones reales usando NHibernate Reflection Optimizer
Quizás algunos van a pensar que esto es una aplicación usando NHibernate, pero la verdad es que no. Como es una aplicación sin NHibernate me las arreglé para convertir DataTables resultados de consultas a objetos de Negocio o colecciones de objetos para poder manejarlos fuera de la capa de Infraestructura de una manera más interesante.
La capa de Infraestructura posee unos helpers para realizar la conversión que nombramos usando algunas convenciones, attributes y reflection! Llega la hora de la optimización y tenemos que afrontar que Reflection no es algo de lo que se debe abusar, pero tampoco está prohibido.
En este post mostraba alguna de las bondades de NHibernate como buen ORM y las optimizaciones que posee a la hora de instanciar objetos, o setear/obtener los valores de las properties o fields.
Los Helpers de datos básicamente están encargados de convertir Datatables a Colecciones de Entidades o simplemente a Entidades. Para esto podemos tener métodos como ser: GetEntities y GetEntity
Las pruebas se hicieron realizaron la misma cantidad de consultas y con los mismo datos en la base. El profiler para realizar las pruebas es DotTrace, de la empresa JetBrains.
Sin optimizaciones:
Con Optimizaciones (NHibernate Reflection Optimizer)
53 llamadas a GetEntities: 111,18 ms. contra los 66,921 ms. del GetEntities con las optimizaciones. Destaquemos aquí que GetEntities solamente realiza conversiones para obtener colecciones y objetos de negocios, y no realiza ninguna hit a la base de datos.
yaml, una alternativa para XML
yaml es un lenguaje de serialización de datos, una alternativa al lenguaje de marcado XML. Es muy interesante, y es muy útil usarlo por que es más legible para el ojo humano que un archivo XML. Está enfocado a la simplicidad. Vamos a ver un ejemplo tomado de la realidad, así es como luciría un archivo de mapeo de NHibernate si fuera escrito en yaml:

Si usas NHiberante, debes darte cuenta que esto es mucho más fácil de leer. Como se puede apreciar la delimitación es hecha por identación. Si conoces lenguajes como Python esto te resultará muy familiar. Por supuesto, esto no está soportado en NHibernate, pero quien sabe, quizás alguien quiere donar algunas horas al OSS y hacerlo
Quizás una notoria desventaja es que yaml no posee esquema (schema). Y podés darte cuenta de las características que nos estamos perdiendo por esto, la más importante: validación de un documento yaml.
En .Net-landia no es tan popular, de hecho no lo es, pero en lenguajes como Python, Php, Perl, C++ se usa mucho. En el nuevo bebé de Google: Google App Engine, el cual tiene como lenguaje principal a Python (actualmente es el único lenguaje que soporta), usa yaml para los archivos de configuración.
XUnit 1.0 – Usando ReSharper como Runner
Hoy me enteré de este lanzamiento que de manera particular lo estaba esperando. Hace un tiempo atrás cuando este proyecto estaba en pañales, estuvimos hablando un poco sobre él.
Recordemos que existen muchos frameworks para realizar Unit Testing, y XUnit es un proyecto particular, tiene diferencias bien marcadas con respecto a otros frameworks como por ejemplo NUnit. Si bien el creador de XUnit es el mismo que creó NUnit, la principal idea de la creación de otro framework de testeo fue alejarse de algunos aspectos intrínsecos que NUnit los tenía fuertemente heredados de su fuente de inspiración JUnit.
Para correr los tests podemos utilizar diferentes runners:
- xunit.console (se distribuye con los binarios de XUnit)
- xunit.gui (se distribuye con los binarios de XUnit)
- TestDriven (se integra con Visual Studio)
- Resharper 3.1 (se integra con Visual Studio)
Aquí tienen una captura para que vean en acción a XUnit corriendo desde ReSharper:

xUnit.Net – Excepciones Esperadas
Para los que no estaban enterados, el autor de NUnit saca a la luz este nuevo Framework de unit testing. La intención de un nuevo Framework de Testing para .Net parecería querer reinventar la rueda, pero no lo es. Muchas practicas que se hacían en NUnit (y muchas de estas heredadas de JUnit) no van a estar disponibles -para bien de nuestro código según argumenta James Newkirk.
Uno de los cambios: No va más el ExpectedException. Y el argumento de su desaparición es válido: Puede que una linea de codigo arroje esa excepción, y no sea la linea de codigo que estamos esperando a que lo haga. Ahora debemos hacerlos así:
[Test]
public void NeuronNotConnected()
{
INeuron n = new SigmoidalNeuron();
Assert.Throws<BpnException>(
delegate
{
double foo = n.Net.Value;
});
}
Esta es la pagina del proyecto http://www.codeplex.com/xunit.
Y para correr los test con Visual Studio pueden usar http://www.testdriven.net/
uNHAddins: UnOfficial NHibernate AddIns
Fabio Maulo, con quien tengo el honor de moderar a NHibernate-Hispano, ah puesto a nuestra disposición este nuevo proyecto llamado uNHAddIns.
UnOfficial NHibernate Addins nos provee recursos para interactuar con NHibernate que no están en la versión Oficial de NHibernate, una especie de paquete Contrib, al cual podemos hacer llegar requerimientos ó inquietudes para tenerlas en cuenta y en un futuro hacerlas formar parte del framework.
Por ahora, ya podemos disfrutar de features: DetachedCriteria, DetachedQuery, DetachedDynQuery y Pagination.
DetachedQuery es el hermano de DetachedCriteria. DetachedCriteria existe actualmente en el core de NHibernate, pero no habia algo similar para HQL.
Se utiliza DetachedQuery/DetachedCriteria en lugares donde no contamos con una ISession. Es un modo de retardar hasta el ultimo momento la asociación del query con la sesión y esto ayuda a jugar mucho en las implementaciones de DAO Genericas.
Recursos:
- Página del Proyecto
- Grupo de Discusión de uNHAddIns.
- LesTroisMousquetaires:DetachedCriteria,DetachedQuery y DetachedDynQuery
- Descargas
Luego postearé codigos de ejemplo, pero pueden unirse al grupo de discución para hacer llegar las preguntas.
SVN y versionado de soluciones Visual Studio
Cuando queremos versionar soluciones de Visual Studio, existen ciertos archivos que se deben incluir en el repositorio, y archivos que no. Si estamos usando Resharper, también vamos omitir los archivos que agrega a nuestras carpetas. La estructura de directorios que propongo es esta:

En este ejemplo para interactuar con el repositorio SVN, utilizaremos Tortoise SVN.
Consideremos una solución winApp, que tiene dependencias con la librería NHibernate.dll, que se encuentra en la carpeta lib. La solución en el Visual Studio luce así:
Los archivos de dicha solución serían los siguientes:
Una vez que tenemos nuestra solución creada, y nuestro repositorio funcionando, realizamos un checkout sobre una carpeta que elijamos, en mi caso es “D:\checkouts”. Ahí estaran los archivos que necesitan sincronizarse contra el repositorio. Luego del checkout, la carpeta seguirá vacia, pero lista para la sincronización.
Ahora copiamos nuestras carpetas “lib” y “winApp” dentro de “checkouts/” para agregarlas al versionado. Las seleccionamos y hacemos: TortoiseSVN -> Add…
Ahora tenemos que seleccionar los archivos que vamos a versionar. Dicho de manera contraria, eliminamos archivos que no deseamos que estén en el repositorio. Los archivos no versionables son:
- Carpeta bin/ y su contenido.
- Carpeta obj/ y su contenido.
- Carpeta _ReSharper.*/ y su contenido.
- Archivo *.resharper
- Archivo *.suo
Y la selección debe quedar similar a esto:
Una vez que agregamos los archivos, realicemos el commit !

Los archivos que no participan en el versionado son los desmarcados. Y luego el repositorio debería lucir así:
Listo, tenemos nuestras solución sincronizada y versionada !
Como tip final, podemos usar AnkhSVN, un plugin para Visual Studio que nos permite gestionar los comandos de SVN desde Visual Studio.
Linking assemblies
Linker, es una libreria que escribió Jb, y se encarga de reducir al mínimo el conjunto de funciones assemblies para que un conjunto de programas puedan correr. En otras palabras, toma las librerias que necesita un programa y elimina de ellas los métodos ó tipos que no son necesarios.
Pueden obtener el código del SVN, y compilarlo. Requiere Mono.Cecil.
Linker es una simple aplicación de consola, y toda la magia ocurre en una sola linea de comandos. Antes que nada, veamos que tenemos. Los archivos necesarios para que la aplicación Mono.Sms.exe funcionen son: Castle.Core.dll, Castle.Windsor.dll, Castle.MicroKernel.dll y Castle.DynamicProxy.dll. Ponemos todos archivos en el mismo directorio que el ejecutable Mono.Sms.exe. Luego ejecutamos:
monolinker -a Mono.Sms.exe -out linkedfiles/ -x descritor.xml
Donde indicamos cual va a ser la aplicación objetivo, el directorio de salida, y el archivo xml descritor con los tipos que se desean preservar despues del proceso de linkeo. Nuestro archivo con los tipos que no queremos que Linker los eliminie es el siguiente:
<?xml version="1.0" encoding="utf-8" ?> <linker> <assembly fullname="Castle.Windsor"> <namespace fullname="Castle.Windsor.Configuration.Interpreters.XmlProcessor.ElementProcessors"/> <type fullname="Castle.Windsor.Configuration.AppDomain.CastleSectionHandler"/> </assembly> </linker>
Con esto indicamos que el namespace ElementProcessors, y el tipo CastleSectionHandler deben ser incluidos en la salida. Este descritor lo tuve que elaborar porque Linker omitia el tipo CastleSectionHandler, y tambíén eliminaba los constructores de los tipos contenidos en el namespace ElementProcessors. Como lo supe? Prueba y error.
Ahora veamos el resultado:
Ahora que hemos reducido, el tamaño de los assemblies, imaginense otra herramienta para juntar todos los assemblies en 1 sólo. La filosofía XCOPY de .Net, se convertiria en la COPY, nada más. Por estos caminos anda también Jb, que según dijo, está reescribiendo a monomerge (actualmente se cae).
Generando aplicaciones con AjGenesis
Este es el titulo del tutorial que nos deja Angel en su blog acerca de su querido AjGenesis.
Dos puntos que destaca Angel son:
- El modelo del que parte es totalmente definible por el usuario
- Las tareas y plantillas a aplicar son totalmente programables y controlables
Y de estos 2 puntos me quedo con el primero que me alcanza y sobra para decir cuan flexible es AjGenesis. Otras herramientas de generación de código muy útiles (vale la redundancia: todas las herramientas de generación de código son útiles) como MyGeneration, permiten la generación de código a partir de un modelo de datos. Esta es una gran diferencia con AjGenesis, esta permite la generación a partir de un modelo libre, no hay restricciones. El modelo lo podemos obtener desde una base de datos, a partir de nuestras clases, o podemos ir desarrollandolo de manera artesanal (a mano).