-
Notifications
You must be signed in to change notification settings - Fork 152
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
Improvements to the NETCORE console runner #1101
Comments
Here is a list of topics I think we need to discuss and make decisions on. I have tried to think very broadly about this and not limit myself to what we are already doing. Feel free to do the same as you suggest additions or changes.
|
@nunit/engine-team Ideas and comments? This seems like a really key decision to make. |
Will there be support for net6.0 now that it's released (three months ago!)? net5.0 won't be LTS, only net6.0, and MS has made it clear that net6.0+ is "the future." |
I absolutely agree. But we need to go a bit further and specify what "support" actually means. One possibility is that we simply build the runner for .NET 6.0 rather than .NET Core 3.1. That would of course mean that your pre-6.0 tests would be running under .NET 6.0. Is that a drawback for some folks? I don't know... which is basically the reason that this item needs discussion. :-) |
I noticed in the runner package (link: https://nuget.info/packages/NUnit.ConsoleRunner/3.14.0) that there appears to be support for netcoreapp3.1 and net5.0, so maybe adding a net6.0 target framework is enough? Not sure it has to be a "rather than" situation. |
In the case of NUnit.ConsoleRunner, you're correct. In fact, there's already an issue to add a .NET 6.0 agent. However, this issue is about the NETCORE console runner, NUnit.ConsoleRunner.NetCore. That runner doesn't have agents for running out of process. Your tests run directly using the target framework for which the runner is built. The NETCORE runner is the one you are using if you type One of the things I want to do is find a new name for this runner package to avoid confusion... hence point 2. :-) So... which runner are you using? |
The latter (NUnit.ConsoleRunner). Sorry for the confusion! And I see the net6.0 agent is coming in 3.15! |
Yes, it is... I delayed it because it requires changing our build to use VS2022. |
First a disclaimer, I've don't think I've used the NETCORE console runner nor any other .Net tools except for the default ones (at least as I know), so my knowledge in this area is very limited.
|
Thanks for the comments @mikkelbu For 3.x I'll keep the existing structure (one project, two builds) and capabilities. The five points above will be the basis for some breaking changes as well as some improvements in the tool for 4.0. For 3.15For 4.0
|
I am trying to run the console runner as a dotnet tool (think this is the "NETCORE" you refer to) on a project targeting .NET 8. The runner fails:
I can't see any actual resolution being proposed and implemented here. Why is that? .NET 8 has been out for a long time now, why does this not work? Is it possible for me to make this work or does it require changes on your side? |
@MJB222398, please take a look at issue #1383. |
I'm writing this to replace issue #858. That issue has become cluttered with a lot of confusing comments... many of them my own. :-( The confusion largely arises because it wasn't always clear whether we were talking about the NETFX runner or the NETCORE runner... both of which have the same name!
In closing #858 I summarized the problem in a comment, which i'll repeat here...
The NETCORE console runner is (unfortunately) called nunit3-console just like the NETFX runner, but it has entirely different capabilities.
The NETCORE runner does not launch agent processes to isolate tests but runs them in-process.
The NETCORE runner has some support for engine extensions, but of course only for extensions, which target .NET Core or .NET Standard. I only know of one such extension... our V2 Result Writer. All our other extensions are NETFX only.
The NETCORE runner itself targets .NET Core 3.1 and is set up to allow rollover to new major versions if 3.1 is not installed. That means the tests it runs have to target .NET Core 3.1 or lower.
Since there is no VS project loader extension compatible with .NET Core, the NETCORE runner can only run assemblies entered at the command-line.
(Everyone... please correct me if any of the above seems wrong!)
I'd like to use this issue to restart the discussion about our NETCORE runner (or runners) and define more clearly where we want to go in coming releases. Once we have made our decisions, this Epic issue will be used to gather all the sub-issues we create to implement them.
The text was updated successfully, but these errors were encountered: