From 2c8cf3beaa20c06411f8eb23b4b24c94e8f19bb4 Mon Sep 17 00:00:00 2001 From: Tsar Nikolay Date: Tue, 8 Oct 2019 15:08:35 +0500 Subject: [PATCH] Custom debug logging for SerializationException. --- .../CustomODataSerializerProvider.cs | 21 +++++++++++++++---- 1 file changed, 17 insertions(+), 4 deletions(-) diff --git a/NewPlatform.Flexberry.ORM.ODataService/Formatter/CustomODataSerializerProvider.cs b/NewPlatform.Flexberry.ORM.ODataService/Formatter/CustomODataSerializerProvider.cs index c6267582..479696f5 100644 --- a/NewPlatform.Flexberry.ORM.ODataService/Formatter/CustomODataSerializerProvider.cs +++ b/NewPlatform.Flexberry.ORM.ODataService/Formatter/CustomODataSerializerProvider.cs @@ -1,13 +1,13 @@ namespace NewPlatform.Flexberry.ORM.ODataService.Formatter { using System; - using System.Collections.Generic; using System.Linq; using System.Net.Http; - using System.Text; - using System.Threading.Tasks; using System.Web.OData; using System.Web.OData.Formatter.Serialization; + + using ICSSoft.STORMNET; + using Microsoft.OData.Edm; /// @@ -43,6 +43,12 @@ public override ODataEdmTypeSerializer GetEdmTypeSerializer(IEdmTypeReference ed serializer = _feedSerializer; } + if (serializer == null) + { + EdmTypeKind edmKind = edmType.TypeKind(); + LogService.LogDebug($"'{edmType.ToTraceString()}' ({nameof(EdmTypeKind)}='{edmKind.ToString()}') cannot be serialized using the '{nameof(CustomODataSerializerProvider)}'"); + } + return serializer; } @@ -61,7 +67,14 @@ public override ODataSerializer GetODataPayloadSerializer(IEdmModel model, Type return _feedSerializer; } - return base.GetODataPayloadSerializer(model, type, request); + ODataSerializer serializer = base.GetODataPayloadSerializer(model, type, request); + + if (serializer == null) + { + LogService.LogDebug($"'{type.Name}' ({nameof(IEdmModel)} type='{model.GetType().Name}') cannot be serialized using the '{nameof(CustomODataSerializerProvider)}'"); + } + + return serializer; } } }