From a5eec4b6716a6a174150906c1d0f7755bde0910d Mon Sep 17 00:00:00 2001 From: Nicholas Blumhardt Date: Tue, 5 Sep 2017 14:08:52 +1000 Subject: [PATCH 1/4] Dev version bump [Skip CI] --- src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj b/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj index 8752163..45a8eb9 100644 --- a/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj +++ b/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj @@ -2,7 +2,7 @@ A Serilog sink that writes log events to the console/terminal. - 3.1.0 + 3.1.1 Serilog Contributors net45;netstandard1.3;netcoreapp1.1 Serilog.Sinks.Console From bc176ad4031d12dc48366785874fc4c1cd269edb Mon Sep 17 00:00:00 2001 From: Matthew Erbs Date: Mon, 11 Sep 2017 14:46:29 +1000 Subject: [PATCH 2/4] Added System.Core for net45. --- src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj | 1 + 1 file changed, 1 insertion(+) diff --git a/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj b/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj index 45a8eb9..693b36a 100644 --- a/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj +++ b/src/Serilog.Sinks.Console/Serilog.Sinks.Console.csproj @@ -38,6 +38,7 @@ + From 63f0a95121209610203dcad1e18a9bf64c0ab15f Mon Sep 17 00:00:00 2001 From: Nicholas Blumhardt Date: Mon, 23 Oct 2017 09:35:56 +1000 Subject: [PATCH 3/4] Apply string literal formatting in display mode (#25) --- Build.ps1 | 8 +++++-- .../Formatting/ThemedDisplayValueFormatter.cs | 7 +++++- .../ThemedDisplayValueFormatterTests.cs | 23 +++++++++++++++++++ 3 files changed, 35 insertions(+), 3 deletions(-) create mode 100644 test/Serilog.Sinks.Console.Tests/Formatting/ThemedDisplayValueFormatterTests.cs diff --git a/Build.ps1 b/Build.ps1 index e4eabf7..ee4117d 100644 --- a/Build.ps1 +++ b/Build.ps1 @@ -24,7 +24,11 @@ foreach ($src in ls src/*) { echo "build: Packaging project in $src" & dotnet build -c Release --version-suffix=$buildSuffix - & dotnet pack -c Release --include-symbols -o ..\..\artifacts --version-suffix=$suffix --no-build + if ($suffix) { + & dotnet pack -c Release --include-source -o ..\..\artifacts --version-suffix=$suffix --no-build + } else { + & dotnet pack -c Release --include-source -o ..\..\artifacts --no-build + } if($LASTEXITCODE -ne 0) { exit 1 } Pop-Location @@ -41,4 +45,4 @@ foreach ($test in ls test/*.Tests) { Pop-Location } -Pop-Location \ No newline at end of file +Pop-Location diff --git a/src/Serilog.Sinks.Console/Sinks/SystemConsole/Formatting/ThemedDisplayValueFormatter.cs b/src/Serilog.Sinks.Console/Sinks/SystemConsole/Formatting/ThemedDisplayValueFormatter.cs index 07bab37..e6b3659 100644 --- a/src/Serilog.Sinks.Console/Sinks/SystemConsole/Formatting/ThemedDisplayValueFormatter.cs +++ b/src/Serilog.Sinks.Console/Sinks/SystemConsole/Formatting/ThemedDisplayValueFormatter.cs @@ -159,7 +159,12 @@ public int FormatLiteralValue(ScalarValue scalar, TextWriter output, string form if (value is string str) { using (ApplyStyle(output, ConsoleThemeStyle.String, ref count)) - JsonValueFormatter.WriteQuotedJsonString(str, output); + { + if (format != "l") + JsonValueFormatter.WriteQuotedJsonString(str, output); + else + output.Write(str); + } return count; } diff --git a/test/Serilog.Sinks.Console.Tests/Formatting/ThemedDisplayValueFormatterTests.cs b/test/Serilog.Sinks.Console.Tests/Formatting/ThemedDisplayValueFormatterTests.cs new file mode 100644 index 0000000..c5c9833 --- /dev/null +++ b/test/Serilog.Sinks.Console.Tests/Formatting/ThemedDisplayValueFormatterTests.cs @@ -0,0 +1,23 @@ +using System.IO; +using Serilog.Events; +using Serilog.Sinks.SystemConsole.Formatting; +using Serilog.Sinks.SystemConsole.Themes; +using Xunit; + +namespace Serilog.Sinks.Console.Tests.Formatting +{ + public class ThemedDisplayValueFormatterTests + { + [Theory] + [InlineData("Hello", null, "\"Hello\"")] + [InlineData("Hello", "l", "Hello")] + public void StringFormattingIsApplied(string s, string format, string expected) + { + var f = new ThemedDisplayValueFormatter(ConsoleTheme.None, null); + var sw = new StringWriter(); + f.FormatLiteralValue(new ScalarValue(s), sw, format); + var actual = sw.ToString(); + Assert.Equal(expected, actual); + } + } +} From 71f07c7aa8f7b9b51ea03602f244620e6b4ea0e0 Mon Sep 17 00:00:00 2001 From: Matthew Erbs Date: Mon, 23 Oct 2017 09:37:11 +1000 Subject: [PATCH 4/4] Code of Conduct, Contributing Guide & templates for issues and PRs (#24) * Added issue and PR templates along with contrib and code of conduct pages. * Link fix. * Update PULL_REQUEST_TEMPLATE.md --- .github/ISSUE_TEMPLATE.md | 25 +++++++++++++++ .github/PULL_REQUEST_TEMPLATE.md | 12 ++++++++ CODE_OF_CONDUCT.md | 3 ++ CONTRIBUTING.md | 52 ++++++++++++++++++++++++++++++++ README.md | 7 +++++ 5 files changed, 99 insertions(+) create mode 100644 .github/ISSUE_TEMPLATE.md create mode 100644 .github/PULL_REQUEST_TEMPLATE.md create mode 100644 CODE_OF_CONDUCT.md create mode 100644 CONTRIBUTING.md diff --git a/.github/ISSUE_TEMPLATE.md b/.github/ISSUE_TEMPLATE.md new file mode 100644 index 0000000..0c1a63a --- /dev/null +++ b/.github/ISSUE_TEMPLATE.md @@ -0,0 +1,25 @@ +**A few questions before you begin:** + +> Is this an issue related to the Serilog core project or one of the [sinks](https://github.com/serilog/serilog/wiki/Provided-Sinks) or [community projects](https://github.com/serilog/serilog/wiki/Community-Projects). This issue list is intended for Serilog core issues. If this issue relates to a sink or related project, please log on the related repository. Please use [Gitter chat](https://gitter.im/serilog/serilog) and [Stack Overflow](http://stackoverflow.com/questions/tagged/serilog) for discussions and questons. + + +**Does this issue relate to a new *feature* or an existing *bug*?** +- [ ] Bug +- [ ] New Feature + +**What version of Serilog Console Sink is affected by this issue? Please list the related NuGet package.** + +**What is the target framework and operating system affected by this issue? Please see [target frameworks](https://docs.microsoft.com/en-us/nuget/schema/target-frameworks) & [net standard matrix](https://docs.microsoft.com/en-us/dotnet/standard/net-standard).** + +- [ ] netCore 2.0 +- [ ] netCore 1.0 +- [ ] 4.7 +- [ ] 4.6.x +- [ ] 4.5.x + +**Please describe the current behaviour you are experiencing?** + +**Please describe the expected behaviour if the ?** + +**If the current behavior is a bug, please provide the steps to reproduce the issue and if possible a minimal demo of the problem** +*NOTE: A small code sample goes a long way in expediting bug fixes or illustrating an enhancement you are proposing.* diff --git a/.github/PULL_REQUEST_TEMPLATE.md b/.github/PULL_REQUEST_TEMPLATE.md new file mode 100644 index 0000000..6994d7f --- /dev/null +++ b/.github/PULL_REQUEST_TEMPLATE.md @@ -0,0 +1,12 @@ +**What issue does this PR address?** +*Please list any GitHub issues here* + +**Does this PR introduce a breaking change?** +*Please list any changes that may cause issues for users, including binary breaking changes* + +**Please check if the PR fulfills these requirements** +- [ ] The commit follows our [guidelines](https://github.com/serilog/serilog-sinks-console/blob/dev/CONTRIBUTING.md) +- [ ] Unit Tests for the changes have been added (for bug fixes / features) + +**Other information**: +*Please list any other relevant information here* diff --git a/CODE_OF_CONDUCT.md b/CODE_OF_CONDUCT.md new file mode 100644 index 0000000..caea530 --- /dev/null +++ b/CODE_OF_CONDUCT.md @@ -0,0 +1,3 @@ +# Code of Conduct + +Please refer to the [Serilog Code of Conduct](https://github.com/serilog/serilog/blob/dev/CONTRIBUTING.md) which covers all repositories within the Serilog Organisation. \ No newline at end of file diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md new file mode 100644 index 0000000..61ee64e --- /dev/null +++ b/CONTRIBUTING.md @@ -0,0 +1,52 @@ +# Contributing to the Serilog Console Sink + +First of all thanks for dropping by, feel free to checkout [Serilog core project's contributing page](https://github.com/serilog/serilog/blob/dev/CONTRIBUTING.md) which contains some key points about the organisation. + +## Reporting an issue + +Bugs are tracked via [GitHub][issue_list] issues. Below are some notes to help create a new issue. The issue template will help you on the way. + +* Create an issue via the [issues list][create_issue]. +* List the version of Serilog that is affected +* List the target framework and operating system +* If possible, provide a sample that reproduces the issue. + +## Requesting a feature/enhancement + +Feature as also tracked via [GitHub][issue_list] issues. Below are some notes to help create an issue. The issue template will help you on the way + +* Create an issue via the [issues list][create_issue]. +* List the version of Serilog that is affected +* List the target framework and operating system +* If possible, provide a sample that reproduces the issue. + +## Making a PR + +* If an issue does not already exist please create one via the issues list. +* Fork the repository and create a branch with a descriptive name. +* Attempt to make commits of logical units. +* When committing, please reference the issue the commit relates to. +* Run the build and tests. + * Windows platforms can use the `build.ps1` script. (This is the script used in AppVeyor builds) + * nix/OSX platforms can use the `build.sh` script. (This is the script used in Travis builds) +* Create the PR, the PR template will help provide a stub of what information is required including: + * The issue this PR addresses + * Unit Tests for the changes have been added. + +## Questions? + +Serilog has an active and helpful community who are happy to help point you in the right direction or work through any issues you might encounter. You can get in touch via: + + * [Stack Overflow](http://stackoverflow.com/questions/tagged/serilog) - this is the best place to start if you have a question + * Our [issue tracker](https://github.com/serilog/serilog/issues) here on GitHub + * [Gitter chat](https://gitter.im/serilog/serilog) + * The [#serilog tag on Twitter](https://twitter.com/search?q=%23serilog) + +Finally when contributing please keep in mind our [Code of Conduct][serilog_code_of_conduct]. + +[serilog]: https://github.com/serilog/serilog +[sinks]: https://github.com/serilog/serilog/wiki/Provided-Sinks +[community_projects]: https://github.com/serilog/serilog/wiki/Community-Projects +[create_issue]: https://github.com/serilog/serilog-sinks-console/issues/new +[issue_list]: https://github.com/serilog/serilog-sinks-console/issues/ +[serilog_code_of_conduct]: https://github.com/serilog/serilog/blob/dev/CODE_OF_CONDUCT.md diff --git a/README.md b/README.md index debeda4..0ba2bc0 100644 --- a/README.md +++ b/README.md @@ -143,6 +143,13 @@ To achieve output identical to version 2 of this sink, specify a formatter and o This will bypass theming and use Serilog's built-in message template formatting. +### Contributing + +Would you like to help make the Serilog console sink even better? We keep a list of issues that are approachable for newcomers under the [up-for-grabs](https://github.com/serilog/serilog-sinks-console/issues?labels=up-for-grabs&state=open) label. Before starting work on a pull request, we suggest commenting on, or raising, an issue on the issue tracker so that we can help and coordinate efforts. For more details check out our [contributing guide](CONTRIBUTING.md). + +When contributing please keep in mind our [Code of Conduct](CODE_OF_CONDUCT.md). + + ### Detailed build status Branch | AppVeyor | Travis