Entradas

Personalizar el DEPLOY con GeneXus

Imagen
En los ciclos de desarrollo se necesita hacer llegar desde la KB hasta el ambiente de producción, con una determinada personalización, para que el sistema funcione en producción.  GeneXus tiene la tarea de Build all bien resuelta, pero aun no contempla el Package ALL, ni el Deploy All, sino que hace el deploy para una deployment unit en forma aislada.  En varias oportunidades surge la necesidad de personalizar los archivos que se necesitan enviar para el deploy. Esto implica cambiar archivos del tipo web.config, appsettings.json, client.cfg, etc.  La personalización permite el ajuste necesarios para un correcto deploy de la aplicación.   De que forma se puede hacer? En un esquema general, se puede hacer el deploy de cada Deployment Unit.  Tanto si se ejecuta la tarea de Deploy desde el IDE de GeneXus, como automatizando las tareas con MSBUILD y jenkins el proceso es similar.  La personalización se puede hacer con el proyecto <DUName>_user.gxdproj , que es un proyecto del usuario,

Herramientas para personalización de instalaciones

Imagen
 En el proceso de desarrollo con GeneXus, surge la necesidad de personaliza archivos en el momento de la instalación cuando se quiere instalar la misma versión para diferentes clientes o en diferente infraestructura.  En el pasaje a producción, en algunos ambientes se puede utilizar la personalización a través de variables de ambientes (por ejemplo con Docker / Kubernetes) pero en otros ambientes esto no es una posibilidad válida, y hay que cambiar archivos de configuración para lograr que todo funcione correctamente.  Algunas de las cosas que es necesario personalizar son los siguientes archivos web.config  y client.exe.config client.cfg PDFReport.ini CloudServices.config rewrite.config log.config y log.console.config log4j.xml connection.gam dockerfile web.xml appsettings.json Con seguridad me faltan varios mas.  El formato de estos archivos es variado (xml, json, txt, ini) y por lo tanto las herramientas que usamos para hacer su personalización también varia.  La personalización pue

Programa Genexus para cambiar codigo GeneXus usando expresiones regulares.

Imagen
  En una KB que tenia muchos años tuvimos que hacerla multi-idioma.  Hay un trabajo grande de poner a los string que no son traducibles el símbolo ! delante.  Por ejemplo donde antes decía where ClienteActivo = 'S' hay que poner where ClienteActivo = EstadoCliente.Activo  o where ClienteActivo = !'S' Hice un programa para leer un archivo de un export de GeneXus y cambiar el código para hacer el segundo cambio.  Lo que hace es recorrer el archivo del export y se fija si esta en una parte modificable (Source, Rules, Conditions, Source de DataProvider o Data Selector, etc) Dentro de esas partes, hay también propiedades, variables, etc que no deberían cambiarse por lo que solo cambia algo si está dentro de una sección <!CDATA.  A su vez, hay varias excepciones que deben contemplarse, por ejemplo cuando se tiene codigo javascript embebido en el código, o comandos CSHARP, JAVA, SQL o los nombres de las Subrutinas que no deben cambiarse, y no se pueden marcar como no traduc

Cambiar atributo a usar valores enumerados

Imagen
En versiones anteriores de Genexus, no se podían tener dominios con valores enumerados.  Esto es un atributo que solo pueda tener los valores que se ponen en una lista y nada mas que esos.  Esta muy bueno también para poner constantes en los programas, sin tener que poner numero o strings con significados mágicos.  Por ejemplo, antes poniamos: PedidoEstado<> !'I'  and PedidoEstado <> !'F'    y con un dominio enumerado se pone PedidoEstado<> Estado.Inicial and PedidoEstado <> Estado.Final * La nomenclatura no es la mejor, pero es para que quede fácil de entender Las ventajas es que el código queda mucho mas claro, y queda referencias donde se utilizan los diferentes valores.  La relación entre el valor que se guarda en la base de datos y lo que tienen los programas esta concentrada en la lista de valores enumerados del dominio o del atributo y no por todos los programas. Cuando cambio la lista, cambia automáticamente en toda la aplicación.  Tam

Sistema LUCIA: 25 años de una KB GeneXus en producción

Imagen
  Se cumplieron los 25 años del Sistema LUCIA en producción (ver el post de los 20 años ) . Es un sistema aduanero , que permite la declaración aduanera de I mportaciones, Exportaciones, Tránsitos y la liquidación de los tributos correspondientes.  También se controlan los requisitos documentales y de controles de diferentes organismos para poder realizar estas operaciones.  Adicionalmente controla las cargas marítimas, aéreas, terrestres, fluviales que entran y salen del país, cruzando las declaraciones de cargas, con las operaciones aduaneras.  Tenemos un equipo maravilloso de arquitectos, programadores, testers, documentadores, mesa de ayuda, abogados, funcionales, dba, devops. Somos 23 personas las que participamos. Si lo comparamos con países de sistemas aduaneros de tamaño similar, logramos mantener el sistema actualizado con menos personas.  La instalacion, operacion del sistema y administración de la infraestructura es realizada por otra empresa. Durante 25 años muchos mas ha

Estado de automatización del proceso del desarrollo con GeneXus (2023)

Imagen
  Hace 4 años publiqué una artículo sobre  Estado de automatización del proceso de desarrollo con Genexus. Con la aparición de los modelos LLM y el ChatGPT (y los modelos similares) se hace posible automatizar algunas tareas del ciclo de desarrollo que antes era imposible hacer en forma automática.  1 ) ANALISIS - Captura de Requerimientos Herramientas: Issue Tracking, Mind Mappers Dificultad: MEDIA Observaciones: En esta etapa, creo que la inteligencia artificial (IA) puede mejorar significativamente la etapa de análisis de requerimientos en el desarrollo de software de las siguientes maneras:   Automatización en la Captura de Requerimientos: Utilizando técnicas de procesamiento de lenguaje natural (NLP), la IA puede analizar y extraer requisitos clave automáticamente de documentos, correos electrónicos y notas.   Validación y Consistencia de Requerimientos: Los algoritmos de IA pueden revisar los requerimientos para detectar inconsistencias, ambigüedades o conflictos, aseg

KBLogAnalyzer - Analizando logs de aplicaciones Genexus (.NET).

Imagen
Problema: Tengo un conjunto de archivos de log, generados con GeneXus, generalmente bastante grandes y tengo que procesarlos para encontrar lentitudes, errores o cosas a mejorar.  Los registros son de la forma: 2023-10-09 16:01:28,930 [31] DEBUG GeneXus.Data.ADO. GxConnectionManager - GxConnectionManager. DecOpenHandles   handle '3799', datasource 'Default', openhandles 1 2023-10-09 16:01:28,991 [31] DEBUG GeneXus.Data.NTier. DataStoreProvider - gxObject:GeneXus.Programs. pxmlconceptos__default, handle '3799' cursorName:P00ME5 2023-10-09 16:01:28,991 [31] DEBUG GeneXus.Data.ADO.GxCommand - ExecuteReader: Parameters @ConId='53' Hice un pequeño utilitario que facilita o acelera el procesamiento Es un cmd llamado KBLogAnalyzer.cmd, que al correrlo pregunta el directorio de logs, el directorio de salida (procesa todos los archivos que estén en ese directorio) y que tipo de procesos se quiere realizar Con eso, procesa los archivos de log, y permite generar lo

Código mas facil de entender - Booleanos positivos

Imagen
Siempre que sea posible, queda mas claro el código para entenderlo mas rapido, cuando se cheque que un booleano sea verdadero (TRUE) en vez de chequear por falso (FALSE).  Por ejemplo, si tenemos // &Not_Authorized es booleano que indica que el usuario no esta autorizado.  if NOT &Not_Authorized      Operacion() else     Msg('Usuario no autorizado') endif es bastante mas difícil de leer que   //&User_Authorized es un boolean que indica si usuario esta autorizado if &User_Authorized    Operación() else    Msg('Usuario no autorizado') endif Tenemos que recordar que el codigo deberia ser lo mas simple posible de entender como cualquier texto en ingles o pseudocódigo y por lo tanto tener en cuenta el nombre y la semántica de las variables booleanas, es algo importante que ayuda entender más fácil.  Este es algo muy sencillo de hacer en el momento que defino la variable booleana, y simplifica su uso posterior.  Son los pequeños detalles que se sumados hacen l

Corregir Errores de Compresión en Archivos JavaScript en Genexus

Imagen
  En algunas ocasiones pasa (generalmente en cambios de versión de GeneXus) que da un error al comprimir los archivos javascript.  Si bien el mensaje es claro, es un warning y el proceso de build all termina con éxito. Por este motivo, a veces no se detecta el problema hasta que llega a producción y es mucho mas caro de corregir.  Por eso, recomiendo mucho sobre todo en las primeras especificaciones/generaciones/compilaciones de una KB en una nueva instalación, prestar especial atención a la compresión de los archivos javascript.  Un caso real Por ejemplo, el caso de la imagen, había un webpanel programado sin pattern que utilizaba un User Control que se instalaba con un Pattern.  Al cambiar la versión del Pattern, se actualizo el UC, cambiando de nombre y todos los objetos generados con el mismo pasaron a utilizar la nueva versión del UC, pero éste webpanel siguió usando el  UC viejo, que ya no estaba instalado.  Al especificarlo, no daba ningún warning y compilaba sin errores.  Solo

Configurar IIS para ejecutar aplicaciones .NET Core

Imagen
Tenía una aplicación GeneXus funcionando correctamente con el server Kestrel.  Cuando cambié la propiedad para ejecutar con el IIS (Internet Information Server) me empezó a dar el error Server Error in Application "application name" HTTP Error 500.19 – Internal Server Error HRESULT: 0x8007000d Description of HRESULT The requested page cannot be accessed because the related configuration data for the page is invalid. Este error me habia pasado antes en aplicaciones .NET Framework (con el generador viejo) y siempre eran por temas de web.config mal formados o por problemas en la configuración del IIS (por ejemplo, quedaba mal el ApplicationHost.config ). En este caso, no parecía ser este el problema y necesité ayuda para encontrarlo. No deja pistas en el Event Viewer ni en los logs mas típicos. Busque por el lado de los componentes de Windows del IIS y no encontré nada. Me faltaba instalar ASP.NET Core Hosting Bundle que se baja y se instala en forma independiente del IIS. Lu