Skip to content

Commit

Permalink
Fixes serilog#1323 - respect explicit format specifiers even when JSO…
Browse files Browse the repository at this point in the history
…N defaults are selected
  • Loading branch information
nblumhardt committed Jun 20, 2019
1 parent a1e9850 commit d953cee
Show file tree
Hide file tree
Showing 2 changed files with 33 additions and 1 deletion.
2 changes: 1 addition & 1 deletion src/Serilog/Rendering/MessageTemplateRenderer.cs
Original file line number Diff line number Diff line change
Expand Up @@ -95,7 +95,7 @@ static void RenderValue(LogEventPropertyValue propertyValue, bool literal, bool
{
output.Write(str);
}
else if (json)
else if (json && format == null)
{
JsonValueFormatter.Format(propertyValue, output);
}
Expand Down
32 changes: 32 additions & 0 deletions test/Serilog.Tests/Rendering/MessageTemplateRendererTests.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,32 @@
using System;
using System.Collections.Generic;
using System.Globalization;
using System.IO;
using Serilog.Events;
using Serilog.Parsing;
using Serilog.Rendering;
using Xunit;

namespace Serilog.Tests.Rendering
{
public class MessageTemplateRendererTests
{
readonly MessageTemplateParser _messageTemplateParser = new MessageTemplateParser();

[Theory]
[InlineData("{Number}", null, "16")]
[InlineData("{Number:X8}", null, "00000010")]
[InlineData("{Number}", "j", "16")]
[InlineData("{Number:X8}", "j", "00000010")]
public void PropertyTokenFormatsAreApplied(string template, string appliedFormat, string expected)
{
var eventTemplate = _messageTemplateParser.Parse(template);
var properties = new Dictionary<string, LogEventPropertyValue>{["Number"] = new ScalarValue(16)};

var output = new StringWriter();
MessageTemplateRenderer.Render(eventTemplate, properties, output, appliedFormat, CultureInfo.InvariantCulture);

Assert.Equal(expected, output.ToString());
}
}
}

0 comments on commit d953cee

Please sign in to comment.