-
Notifications
You must be signed in to change notification settings - Fork 327
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add .NET Standard 2.0 build #14
Conversation
@@ -61,21 +61,14 @@ pipeline { | |||
// run docker container | |||
builder.inside { | |||
// compile | |||
sh "nant compile-netstandard" | |||
sh "dotnet build src/log4net.csproj -c Release -f netstandard1.3 -o ../bin/netstandard1.3" | |||
sh "dotnet build src/log4net.csproj -c Release -f netstandard2.0 -o ../bin/netstandard2.0" |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would prefer this to be a separate stage.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I just now realized why you had to change this. The docker microsoft/dotnet is now on debian stretch which does no longer include nant (https://packages.debian.org/search?suite=all§ion=all&arch=any&searchon=names&keywords=nant). We probably should move away from nant entirely.
log4net.build
Outdated
<!-- these targets build lognet assemblies against .NET Core (.net standard 1.0.4)--> | ||
<target name="compile-netstandard" description="Builds .NET Core"> | ||
<!-- these targets build lognet assemblies against .NET Standard 1.3 and 2.0 --> | ||
<target name="compile-netstandard" description="Builds .NET Standard"> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I would prefer this to become the target compile-netstandard-1.3
and a second target should be added named compile-netstandard-2.0
. Otherwise too many different targets and builds are done by one target and maintaining it becomes a hard task.
@@ -321,7 +321,7 @@ public void DoAppend(LoggingEvent loggingEvent) | |||
{ | |||
ErrorHandler.Error("Failed in DoAppend", ex); | |||
} | |||
#if !MONO && !NET_2_0 && !NETSTANDARD1_3 | |||
#if !(MONO || NET_2_0 || NETSTANDARD1_3 || NETSTANDARD2_0) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I see a naming scheme difference here. According to the conventions so far, a underscore has been there before the version of a target. Thus NETSTANDARD1_3
should probably read NETSTANDARD_1_3
and NETSTANDARD2_0
should become NETSTANDARD_2_0
. Of course this has slipped through when netstandard-1.3
support was added.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I used the FrameworkMajor_Minor convention because it's used by the build system, e.g. NETSTANDARD1_3
is defined when building a netstandard1.3
library (more details in the Target Frameworks doc).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Then this is fine by me.
src/CompatibilityExtensions.cs
Outdated
|
||
namespace log4net | ||
{ | ||
internal static class CompatibilityExtensions |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Where are these used? docstrings are also missing.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Throughout the netstandard1.3
library, wherever a simple substitution is required. I thought it better than adding conditional compilation around every such instance. The diff is misleading here; this file isn't new but moved, from netstandard/log4net
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It is odd to me that this class in the root namespace. I would prefer a namespace log4net.extensions and probably also split up all the extensions into separate classes like MutexExtensions
and so on.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's in the root namespace to avoid sprinkling something like this throughout the project:
#if NETSTANDARD1_3
using log4net.Extensions
#endif
My thinking here is that these extensions implement simple method substitutions, aren't part of log4net's public surface, and are only visible to a developer working specifically in the netstandard1.3
context (where they're unlikely to be noticed), so it's convenient to keep them together.
#if NETSTANDARD2_0 | ||
catch(PlatformNotSupportedException) | ||
{ | ||
writer.Write("WindowsIdentity is not available on this platform"); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Could this make use of nameof(WindowsIdentity)
?
@@ -17,7 +17,7 @@ | |||
// | |||
#endregion | |||
|
|||
#if NET_4_5 || NETSTANDARD1_3 | |||
#if NET_4_5 || NETCOREAPP1_0 || NETCOREAPP2_0 |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
So far the constant NETSTANDARD1_3
has been used, here it becomes NETCOREAPP1_0
, is this intended?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, because the test project builds an executable artifact for a specific platform. The most convenient way to test the netstandard1.3
library would be with a project targeting netcoreapp1.0
or netcoreapp1.1
.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
hm, not obvious. Would a comment help? Or maybe change it to read as:
#if NET_4_5 || (NETSTANDARD1_3 && NETCOREAPP1_0) || (NETSTANDARD2_0 && NETCOREAPP2_0)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I find that less clear because it confuses .NET Standard and .NET Core, and suggests targeting netstandard1.3
and netcoreapp1.0
simultaneously, which is bizarre. A .NET Standard version is similar to a PCL profile here: an abstract, runtime-agnostic API contract, not a platform on which code runs. Test projects build executables because tests must run on some platform, like .NET Core.
Currently multitargeting tests doesn't work, separate projects are required. | ||
(tracked at https://github.com/Microsoft/vstest/issues/298 and https://github.com/Microsoft/vstest/issues/624) | ||
--> | ||
<TargetFramework>netcoreapp2.0</TargetFramework> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If this is the case, should we add multiple test projects targeting different frameworks?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think that would add clutter for little gain. My understanding is that the csprojes, which currently only target .NET Framework 4.5, are for developing in Visual Studio. Testing everything is left to Jenkins and nant. So I think it reasonable to continue with a single test project for development convenience, at least until there's a more graceful way to multitarget.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually, there should be one and only one way to build the project and that way should be used by developers and CI. Right now we have nant and it looks like latest microsoft/dotnet docker image bases on debian stretch which no longer comes with nant. We could work around that for now, but my impression is that we should move away from nant as soon as possible. To me it looks like it is no longer maintained and we should no longer invest into a sinking ship. This means that ideally we would have one project file that builds all targets and another one that tests all targets. Now testing all targets does not work right now, so we need multiple projects for that usecase.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I agree about nant. However, it is nice that it's stable for the .NET Framework and Mono builds, and works well enough in your CI. Building entire releases from one project is somewhat complex here because log4net has so many targets. In particular, I don't know enough about Mono <--> .NET Framework interop to know whether MSBuild can reasonably build for both in a Linux environment.
I'm pleased to say that I was able to merge large parts of your work into the branch #6 failed in stage I'm now working on the branch I'm not sure how we should proceed with this pull request. What do you think? |
Glad the build works. I expect CI will be blocked until there's some resolution for nunit/nunit3-vs-adapter#377, and I suppose there's also a decision to make about the exclusive locking test. The failure isn't a regression from Since you've merged this code into a feature branch, I think we can close this PR, and I'll base anything further on that branch. Do we need an issue somewhere to track work needed before a release supporting |
Alright, let's move further discussion to JIRA (LOG4NET-572, LOG4NET-567). I would have to craft a commit to close the pull request, would you please close it? |
I don't think it's needed anymore with Neststandard 2.0 to modify the file "log4net.Config.XmlConfigurator" like this : https://github.com/apache/logging-log4net/blob/master/src/Config/XmlConfigurator.cs#L164, because in Netstandard 2.0 you can use "Assembly.GetCallingAssembly()". As example, it's needed to use log4net with Common.Logging (see net-commons/common-logging#167) in ASP.NET Core 2.0. I tried successfully to remove the "#if !NETSTANDARD1_3" of the file, recompile and use the modified dll with Common.Logging and it works fine. Maybe I'm missing something here, but it maybe is a good idea to revert this change ? Thanx.. (first msg deleted by mistake) |
This adds a netstandard2.0 build consumable on .NET Core 2.0, .NET Framework 4.6.1+, Xamarin platforms, and the next version of UWP (this doc has a complete support matrix).
Compared to the netstandard1.3 build, it shares much more code with .NET Framework builds. Some classes still aren't available:
A few classes are supported on Windows alone because they PInvoke Win32 DLLs. These throw PlatformNotSupportedException on non-Windows platforms:
Similarly, UserNamePatternConverter is included but will raise a PlatformNotSupportedException when it tries to get the current WindowsIdentity on a non-Windows platform. It catches and reports this exception.
I also include csproj files for developing with Visual Studio 2017. The new log4net.csproj enables building assemblies for all .NET Framework and Core platforms, and packing them with NuGet. It has some limitations outside of Visual Studio 2017:
net*
assemblies with Mono