Hola en la comunidad Agile Peru se organiza muchos dojos, de hecho se viene una semana de dojos facilitados por diferentes miembros de la comunidad, he visto que se están armando con niveles (básico, intermedio y avanzado) (actualizacion: se han retirado los niveles) pero no se ha indicado en que consisten estos niveles, esto es un poco difícil pues los dojos son para aprender/practicar algo, y esto es muy difuso pues este algo puede ser desde un lenguaje, framework o técnica pero seria bueno tenerlo en algún lugar para saber si estoy interesado y cual me conviene mas
Sin embargo creo que principalmente nos centramos en habilidades de programación asi que quiero proponer una escala:
Esta es una iniciativa de un grupo de miembros de la Comunidad Agile Peru para difundir el pensamiento Craftsmanship, si sabes de algún evento relacionado a la programación avísanos para publicarlo, este espacio es para ti.
viernes, 29 de junio de 2012
martes, 12 de junio de 2012
Mas que un nombre
Hace un par de semanas tuve un pequeño debate con el DBA del
lugar donde trabajo, sobre el uso de convenciones a la hora de usar Nhibernate
en un proyecto nuevo.
Cuando me pidió un ejemplo de como se llamarían las tablas y
las columnas del nuevo sistema, le mostré los resultados, a los 2 mins de ver
los nombres de las tablas resultantes después de crear el esquema con Nhibernate,
la cara de asombro poco a poco fue tornándose en una cara de angustia, estupor
y finalmente contrariedad, y a los pocos segundos dijo:
NOOOOOOOOOO!!!! Eso esta mal, las tablas y columnas no
pueden nombrarse así, para eso esta el estándar!!!, ya hay un documento donde
se explican los mnemotécnicos a usar.... esto esta muy mal!!!.
Primero hablamos acerca del estándar al que hacia
referencia, el cual había sido utilizado en un proyecto legacy que se había
construido hace casi 5 años y que lamentablemente en ese proyecto se había
descuidado el tema sobre las convenciones de programación, nombres, etc...
Y que en el nuevo proyecto habíamos decidido aplicar clean
code en el sentido completo de lo que ello implica.
A todo esto indico que, estaba mal porque no podía aplicarse
a tablas y columnas ya que no eran programas y que los mnemotécnicos eran más
que claros,
a esto le replique que leyera tal cual los nombres de las
tablas del anterior sistema, para lo cual el leyó usando ya su previo
conocimiento del dominio del sistema, por lo que no leyó si no interpreto los
nombres, le replique que eso estaba mal y le dije que si una tabla se llama
rcmcred se leía ere-ce-eme-ce-ere-e-de (exagere un poco) pero quería demostrar
mi punto de vista... el soltó una risa burlona y dijo que la leyera como debería
ser es decir erecemecred... le dije que no era así.... luego le mencione que el
nombre podría ser "deudoresregistrocrediticio" y me dijo que muy
largo yo le dije que podría ser registrocrediticio a lo que el replico, ya ves
ya tiene 2 nombres posibles, en cambio con los mnemotécnicos solo tendría uno y
estaría en el diccionario de datos.....
Y le dije, bueno no tiene dos nombres por el momento tiene 2
posibles nombres aun no la habíamos bautizado =D, entonces él dijo: pero
entonces el nombre podría ser toda la descripción que esta en el diccionario de
datos y con ello estaría bien...
le replique que eso era un extremo y que los extremos no son
buenos, y además que una ventaja de nombrarlo RegistroCrediticio, ya por si
mismo daría una noción de lo que es según el contexto (dominio) y no tendría
que hacer un select adicional para buscar en el diccionario de datos para poder
consultar la descripción de la tabla, a lo que agregue que lo mismo ocurre con
los campos no tiene ningún sentido poner c_codper para guardar el código de la
persona debería ser "codigopersona" o "id", además c_codper
es un campo con solo números y ceros a la izquierda que tal vez después
cambiemos el tipo por temas de negocio y la c_ no tenga nada que ver con el
tipo de dato ya que esa es la intención de pre-fijarla c_, y le hice ver que lo
mismo ocurría las variables, métodos, clases etc...
El asintió pero dijo "entonces para que estaría el
diccionario de datos si la descripción ya no seria necesaria?"
Le dije pues que para información complementaria u otro fin
que permitan un mejor entendimiento si no conoces muy bien el dominio del
sistema.
Y me dijo NOOOO!!!! el diccionario tiene su función, además
las buenas practicas (según un fabricante muy renombrado en el mundo de las
BD), menciona que es una buena practica el uso de mnemotécnicos, y hay
documentos que sustentan lo que digo, y bla y bla y bla... todo ello orientado
a la base de datos que usamos aquí.
le comente además que si hacia una búsqueda usando el
buscador de objetos o una búsqueda de texto dentro de los objetos del
diccionario de datos, consultar seria sencillo porque sabría el significado de
los resultados de la búsqueda con solo leerlos, sin necesidad de ir al
diccionario de datos.
a lo que finalmente termino la conversación diciendo
"yo no estoy de acuerdo. y quien debería definir esto es el gerente de TI,
pero YO NO ESTOY DE ACUERDO... y solo aceptare eso si el gerente de TI me dice
que lo haga, debe usarse el diccionario de datos".
a lo que quiero llegar es que un nombre bien escrito,
auto-descriptivo, ya sea de una variable, método, clase, interfaz, archivo,
tabla, campo, esquema, librería, namespace, test, etc... permite que el Código
sea legible
Código legible no necesita comentarios explicativos, es
entendible por si mismo.
Código legible es mas fácil de entender por ende mantener
PERO es uno de los atributos que ayudan al mantenimiento hay muchos mas, de los
cuales hablaremos en este blog.
Código legible parte de la documentación, complementando a
los test, historias de usuario, etc.
con ello mejora:
la calidad del ambiente de trabajo, no tienes que perder
horas de horas tratando de Descifrar el código, vas de frente a la vena ;-)
el código es leído y entendido por todo el equipo
incluso para el nuevo staff la transición es mucho más
sencilla
por tanto mi recomendación es que piensen en lo nombres que
le ponen a sus variables, clases, test, namespaces, métodos, etc...
porque los nombres son importantes, y el nombre que les den
deben estar dentro del contexto de la solución que están desarrollando y su
significado solo trasciende hasta esos límites
el nombre debe ser un elemento diferenciador entre elementos
dentro de mismo ámbito.
no hay una regla general para esto y tampoco mi intención es
dar un estándar, el equipo debe ver la forma de como ese estándar, esas
convenciones emerjan.
así que piensa en un nombre ;-) no lo tomes a la ligera...
Suscribirse a:
Entradas (Atom)