-
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
Combine two NUnit3 Drivers #1597
Conversation
This is still in progress, but comments are helpful anyway, especially about direction I'm taking. The first two commits result in a combined driver using conditional compilation. The driver has the working name of Currently the conditional code is scattered around the file, but that will change in the next commit. |
The third commit wraps the two APIs in individual classes and implements a compile-time strategy pattern using API2009 for .NET Framework and API2018 for .NET Core. |
Fourth commit does some refactoring and removes the two classes being replaced. Tne new driver is called At this point, the choice of interface is still determined at compile time. I've tried two different approaches for making the decision at runtime and neither worked. See #1596 for discussion of problems. |
The fifth and sixth commits don't advance towards the goal, but perform refactoring to make further progress easier. The various Api classes moved into separate files in the fifth commit. In the sixth, I remove extraneous code from TestAgentRunner, which is based on the possibility of having multiple drivers execute in the same appdomain. This has been unused for some time since there is a one-to-one mapping across test assemblies, agents and domains. |
The seventh commit finally reaches the goal of running .NET Framework tests using the 2018 API. It's a pretty big change, doubling the number of files affected and, unfortunately, making a number of unrelated changes that were needed. A key problem was that a newly created driver didn't have an ID set in it's constructor. Rather, it was set later after construction - usually immediately after. There were various alternative ways to handle this, all a bit disruptive. I chose to modify the constructor for the driver as well as the Remaining to do:
@manfred-brands This is still WIP but please take a look. Let me know if you'd rather see this as several PRs. Now that I know it works, I can easily create a new PR for the first six commits and make the rest of it a second PR. UPDATE: Failing CI due to .NET 7.0 not installed. For now, I made sure it's installed. I'll remove it and add .NET 9.0 in a separate issue and PR. |
1613374
to
b9ce49c
Compare
The eighth commit refactors the tests in order to ensure that both APIs we support under .NET Framework are tested. An internal constructor is added to The driver now switches between the 2009 and the 2018 APIs based on the version of NUnit in use. I was happily surprised to discover that the new API works for versions 3.2 and higher. Very rudimentary package tests have been added to ensure that the switching takes place correctly, but for most cases we now use the newer API. If problems arise, it would be possible to add some sort of switch (e.g. an environment variable) to force use of the older API. I don't see much point in exposing it as a command-line option. This is now ready for review. @manfred-brands See my earlier comment about splitting it up if it seems desirable. |
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 didn't get through it completely. Will continue this afternoon.
The global change looks great, there are some knitpicking things.
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2009.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
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.
A few more comments/questions.
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2018.cs
Outdated
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core/Drivers/NUnitFrameworkApi2009.cs
Outdated
Show resolved
Hide resolved
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.
A few small item and one question about the location of the EnterContextualReflection
calls.
var type = _frameworkAssembly.ShouldNotBeNull().GetType(typeName, throwOnError: true)!; | ||
return Activator.CreateInstance(type, args)!; |
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.
This is where the using (_assemblyLoadContext.ShouldNotBeNull().EnterContextualReflection())
should be called as dependencies are loaded when calling GetType
or CreateInstance
.
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.
Not needed in our tests, but it's certainly possible it may be needed in some situation. Maybe try a test that depends on a different version of TestCentric.Metadata
than the one we use. It's supposed to work as a result of our creating a special context for the tests - equivalent to the NetFramework approach of using a separate AppDomain.
src/NUnitEngine/nunit.engine.core.tests/Drivers/NUnitFrameworkDriverTests.cs
Show resolved
Hide resolved
src/NUnitEngine/nunit.engine.core.tests/Drivers/NUnitFrameworkDriverTests.cs
Show resolved
Hide resolved
@manfred-brands Great review. I think the code is improved a lot. Sorry it was such a slog. I think I'll try to split big things into smaller PRs for review, even if they don't represent a releasable increment. You'll need to either re-approve or merge the PR. It appears that I've lost my ability to force a merge, likely as a side effect of turning on the automatic reviewer selection feature. |
I'm happy to leave the |
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.
Approved. Assuming you have a pending commit with the small changes.
I'm not sure what didn't get in. With such a large set of changes, I use "resolved" to keep track of what I need to pay attention to, resolving each item after I have changed the code or made a comment that may question the suggestion or disagree with it. Anyway, I'll double-check. UPDATE Apparently this works better if you actually push your changes. :-) |
Fixes #1596