Ir al contenido principal

Programación defensiva

Nos vamos dando cuenta de que programar con todas las de la ley cuesta, y cuesta mucho. Para muestra un botón. Esta es una pequeña muestra de lo que contamos. Esta es una primera versión a la rápida de un código que revisa la versión de la aplicación contra la de la base de datos.

string[] version = ConfigurationManager.AppSettings["version"].Split('.');
int mayor = Convert.ToInt32(version[0]);
int menor = Convert.ToInt32(version[1]);
int? resultado = 0;

DSVersionTableAdapters.VersionCheckTableAdapter adapterVersion =
new DSVersionTableAdapters.VersionCheckTableAdapter();
adapterVersion.GetData(mayor, menor, ref resultado);

if (resultado == 0)
{
log4net.ILog log = log4net.LogManager.GetLogger("Standard");
log.Fatal("No está con buena versión: APP(" + version + ") con la base de datos");
}


Esta es la segunda versión de exactamente el mismo código con un poco de programación defensiva.
string[] version = null;
int mayor = 0;
int menor = 0;
int? resultado = 0;

try
{
version = ConfigurationManager.AppSettings["version"].Split('.');
mayor = Convert.ToInt32(version[0]);
menor = Convert.ToInt32(version[1]);
}
catch (Exception err)
{
log.Fatal("No se encuentra la variable de versión", err);
throw new ApplicationException("No se encuentra la variable de versión, arreglar el Web.config. Debería tener la línea add key=version value=1.0.X", err);
}

try
{
VersionTableAdapters.TBLVERSIONTableAdapter adapterVersion =
new VersionTableAdapters.TBLVERSIONTableAdapter();
adapterVersion.GetData(mayor, menor, ref resultado);
}
catch (Exception err)
{
log.Fatal("No existe la tabla de las versiones");
throw new ApplicationException("La tabla de versiones NO se encuentra o NO tiene una línea de versionamiento", err);
}
if (resultado == 0)
{
log.Fatal("No está con buena versión: APP(" + version + ") con la base de datos");
throw new ApplicationException("La versión de la base de datos NO corresponde con la de la aplicación. Revise la tabla TBLVERSION y el fichero web.config");
}

Es algo que muchísima gente lo hace y lo hace muy bien, pero últimamente he visto algunos ejemplos desprolijos (incluyendo míos y valía la pena la reflexión).

Por otro lado, no importa el código en sí pero si algo hay que saber es que el código con progrmaación defensiva y log/trace es algo así como 6 a 7 veces más grande que el código que contempla solamente el mejor caso.

Así que si haces algo desprolijo, es probable que en realidad sea 6 veces más largo para que sea como la gente

Comentarios

Entradas más populares de este blog

Protocolos, qué son?

 En el pasado (y en el presente también) siempre he querido incluir en el contenido de la materia de estructura de datos la posibilidad de hacer un práctico que tenga que ver con redes. Este breve artículo trata de cómo se pueden conectar dos computadoras en red y de las bases por las cuales tenemos protocolos. Veremos: Significado de las direcciones IP y conceptos muy básicos de redes Cómo usar sockets para abrir canales de comnicación entre dos computadoras Concepto de un protocolo y de cómo podemos usar uno para hacer un chat básico Conceptos básicos de redes Si eres de sistemas o te interesan las computadoras pues probablemnte el concepto de conectar dos computadoras en la red parece algo tan sencillo como respirar. Sin embargo, hasta mediados de los 90 era algo que: 1) era complejo; 2) tenía atisbos de magia negra. Por suerte con el tiempo esto se ha ido masificando y ahora es algo muy sencillo. Para poder conectarnos con otra computadora debemos conocer la dirección y el puerto d

Nuget muy grande en tu carpeta personal

Problema : Veo que mi disco duro C ha crecido bastante y necesito espacio. Cuando veo que una carpeta .nuget dentro de mi cuenta de usuario tiene 15 GB. Solución : Esa carpeta existe como cache para que VS no busque el paquete cada vez desde la web. Entonces, la solución consiste en los siguientes pasos. Listar cuales son los folders o contenedores de estos paquetes nuget dotnet nuget locals all --list http-cache: <USER>\AppData\Local\NuGet\v3-cache global-packages: <USER>\.nuget\packages\ temp: <USER>\AppData\Local\Temp\NuGetScratch plugins-cache: <USER>\AppData\Local\NuGet\plugins-cache Limpiar las direcciones que tienen estos paquetes nuget con el utilitario de nuget dotnet nuget locals http-cache --clear Clearing NuGet HTTP cache: C:\Users\Vladimir\AppData\Local\NuGet\v3-cache Local resources cleared. y así para cada uno de los locals que se ve en la lista anterior. Luego se debe cambiar las variables de entorno para que esto no nos vuelva a pasar. Como se

Hangfire, si no lo estás usando, estás haciendo algo mal (.NET world)

Hangfire es una librería espectacular que permite encolar tareas en un servidor de tareas que funciona dentro de tu aplicación web. Existen varios tutoriales que muestran de manera bastante sencilla cómo puedes ir integrando esto a tu aplicación. En esta publicación vamos a repetir, pero en español, y sobretodo vamos a tratar de ir lo más al punto posible. Qué es? Es una librería que la cargas a través de NUGET como cualquier otra librería. En realidad tenemos que cargar 3 librerías pero eso lo veremos más adelante. Una vez que hayas cargado todo lo necesario en tu aplicación web tendrás lo siguiente: Un servidor de colas : es decir, un lugar al cual le puedes mandar hacer cosas y no se olvida de esas cosas y las va ejecutando a medida que puede o tiene tiempo. Esto es muy útil para que tu aplicación no pierda tiempo haciendo algo que no necesita realmente hacer en ese instante y devolver más rápido al usuario final. Un tablero de control de colas : una serie de