En el primer artículo nos centramos en FakeLogger T para aserciones simples y puntuales del logger. Ahora damos un paso más con FakeLoggerProvider, capturando todo el logging del sistema, conectándolo opcionalmente a ILoggerFactory y validando sobre instantáneas completas en lugar de solo el último registro. Esta técnica resulta ideal cuando registran múltiples categorías durante una petición, el orden importa como en recorridos warning seguido de error, quieres afirmar la presencia o ausencia de patrones específicos, o pruebas frameworks tipo pipeline como FastEndpoints. Todos los ejemplos se apoyan en .NET 8 o superior y en el paquete Microsoft.Extensions.Diagnostics.Testing.
Cuándo usar cada opción en pocas palabras: si solo necesitas comprobar una categoría de logger, utiliza FakeLogger T. Si necesitas observar todas las categorías a la vez, emplea FakeLoggerProvider. Cuando el framework construye loggers mediante una fábrica, registra también un ILoggerFactory. Si quieres consultar todos los registros con LINQ, usa provider.Collector.GetSnapshot para obtener una lista inmutable.
Qué ofrece FakeLoggerProvider: actúa como un proveedor de logging estándar y recopila cada LogRecord. Expone Collector.LatestRecord para el último registro, Collector.GetSnapshot para obtener una lista inmutable de todos los registros en orden de llegada, acceso a valores estructurados mediante StateValues, excepciones en record.Exception y ámbitos en record.Scopes si tu código usa BeginScope.
Patrón mínimo de uso con FastEndpoints y fábrica de loggers: registra FakeLoggerProvider como ILoggerProvider en el contenedor de pruebas, crea una instancia concreta de LoggerFactory con ese proveedor y regístrala como ILoggerFactory para que cualquier resolución de ILogger fluya por tu proveedor. Ejecuta el endpoint con un id válido, toma una instantánea con GetSnapshot, filtra por la categoría correspondiente al tipo del endpoint y ordena por marca de tiempo. A partir de esa lista puedes afirmar el orden de los niveles Information, Debug, Information, comprobar que existe un mensaje que contiene Returning thing y leer valores estructurados como ThingId dentro de StateValues.
LatestRecord frente a GetSnapshot: usa LatestRecord cuando esperas exactamente un registro o como comprobación rápida de que algo se ha escrito. En cuanto necesites filtrar, ordenar o razonar sobre el conjunto completo, utiliza GetSnapshot y aplica LINQ, lo que aporta claridad y estabilidad a tus pruebas.
Cómo manejar la ausencia de logs: si aún no hay registros, LatestRecord lanza InvalidOperationException. En casos donde validas ausencia, captura la excepción o, más simple, afirma que el snapshot está vacío con Assert.Empty sobre GetSnapshot.
Ejemplo de comprobación de warnings en escenarios not found: realiza FirstOrDefault sobre el snapshot buscando registros con nivel Warning y un mensaje que exprese la imposibilidad de encontrar el recurso por nombre de usuario. Asegúrate de que tu código de producción escribe mensajes consistentes y, si usas plantillas, que los nombres de las claves sean estables.
Estado estructurado y scopes: los mensajes con plantillas nombradas como Id ThingId exponen pares clave valor en StateValues, lo que permite aserciones precisas sobre datos de negocio. Si tu código utiliza BeginScope, puedes inspeccionar Scopes para verificar etiquetas contextuales, correlaciones o metadatos transaccionales.
Cuándo debes registrar un ILoggerFactory: algunos frameworks o utilidades solicitan explícitamente la fábrica. Si solo registras el ILoggerProvider, podrían crear una fábrica propia y omitir tu proveedor. Evítalo proveyendo una instancia de LoggerFactory que incluya tu FakeLoggerProvider. Si utilizas varios proveedores, inicializa la fábrica con todos ellos para consolidar el pipeline de logging.
Errores frecuentes y su solución: no se capturan logs porque el proveedor se registró después de crear el sistema bajo prueba, solución registrar antes de construir el endpoint o el host. LatestRecord lanza en listas vacías, solución usar GetSnapshot para escenarios defensivos. Filtrado por categoría incorrecto, solución comparar la categoría con el nombre completo del tipo que estás probando. Falta de valores estructurados, solución usar plantillas con nombres en las llamadas a LogInformation o similares, por ejemplo Id ThingId en lugar de concatenar cadenas.
Atajo útil con FastEndpoints: crea un helper de pruebas que construya el endpoint y devuelva también el FakeLoggerProvider ya registrado. Así estandarizas el arranque, garantizas un único pipeline de logging y simplificas tus aserciones por categoría, orden y contenido estructurado.
Conclusión práctica: FakeLoggerProvider eleva tus pruebas de logging desde aserciones sueltas a una observabilidad completa del pipeline. Al combinarlo con una ILoggerFactory explícita consigues un comportamiento determinista, amigable con frameworks como FastEndpoints y robusto para escenarios donde intervienen múltiples categorías y niveles. Empieza con FakeLogger T para lo sencillo y cambia a proveedor más fábrica cuando necesites ordenar, filtrar y validar el conjunto de mensajes.
En Q2BSTUDIO diseñamos y ejecutamos pruebas de calidad y observabilidad para plataformas .NET, además de construir aplicaciones a medida y software a medida con prácticas de ingeniería robustas, pipelines CI CD y monitorización desde el primer día. Si buscas un partner para transformar tu plataforma con arquitectura sostenible, telemetría avanzada y pruebas automatizadas, descubre nuestro enfoque en desarrollo de aplicaciones y software a medida.
Nuestro equipo también impulsa proyectos de inteligencia artificial e ia para empresas con agentes IA y modelos adaptados al dominio, servicios cloud aws y azure con despliegues seguros y escalables, ciberseguridad y pentesting de extremo a extremo, y servicios inteligencia de negocio con cuadros de mando y power bi. Sea cual sea tu caso de uso, desde automatización de procesos hasta analítica avanzada, te ayudamos a crear soluciones mantenibles, seguras y listas para crecer.
Palabras clave recomendadas para este tema y servicios asociados: aplicaciones a medida, software a medida, inteligencia artificial, ciberseguridad, servicios cloud aws y azure, servicios inteligencia de negocio, ia para empresas, agentes IA, power bi, automatización de procesos, FastEndpoints, .NET 8, pruebas de logging, observabilidad, snapshots de logs, ILoggerFactory, FakeLoggerProvider.