VSIX based Test Adapters to be deprecated in Visual Studio for C# and Visual Basic to speed up testing
By terje
Test Adapters come in two flavors, VSIX based and Nuget based. The VSIX based are installed as extensions to Visual Studio and therefore will apply to all solutions you load, The Nuget based adapter packages must be installed at least into one project in your solution and will only work for that solution.
All versions of Visual Studio have supported both flavors, but from Visual Studio 2017 Update 15.8 (Preview 4) the VSIX based adapters for C# and Visual Basic will be deprecated.
Also, you will need to install the nuget test adapter package into all test projects. See below for details.
One of the reasons for this, is that you can gain a significant speed increase especially when you execute just a few tests out of many. Since test execution speed is very essential to a good development flow this should be greatly appreciated.
Note 1: VSIX will still be supported and enabled by default, but to gain the performance boost, you should switch. Moving forward, at first you must “opt out” of using VSIX - if installed, but one should expect it to move towards “opt in” or completely being removed in an even later version. So with “deprecated” it means they will still be supported. In the longer term, the “supporting” will be taken out, but there is no time frame for that now. You’ll however be wise to start moving over sooner than later.
Note 2: VSIX for all other languages, like C++, JavaScript, Python and others, will still be fully supported. This change will only apply to C# and Visual Basic projects.
Actions you should take You should start to add the NUnit3 Nuget TestAdapter (or if you’re still on NUnit2 use the NUnit2 TestAdapter) to at least one project in each solution you have.
And then you should uninstall your VSIX adapter.
By uninstalling the VSIX adapter you will
- More easily see which solutions are still missing the test adapter package
- Avoid having the VSIX adapter taking precedence over the nuget adapter, because that is what happens currently when you have both. With the VSIX installed, you don’t see if the nuget adapter is actually working. (Note: This applies “pre-change”, see below)
The same procedure applies if you use any other VSIX based adapter where there exist a matching Nuget based adapter. If you’re using MSTest 1 VSIX, then you can switch to the MSTest 2 nuget based adapter.
[Important!] Installing the adapter package into all projects When you install the test adapter package, you choose to install it just into one project, but in upcoming Visual Studio versions you must install the adapter into all test projects you have. Adding it to a single project only will no longer work.
This will also enable the optimisations making the adapter loading faster if they are present in the binary output folder.
With the new project format this is much easier (read: faster) to change than with the old format, since it is just a copy/paste operation into the csproj file, see this post for an example. The csproj file can be accessed through the context menu Edit XXXX.csproj without having to unload the project. With the old format the most easy way is to go through the Tools/Nuget Package Manager/Manage NuGet Packages for Solution dialogue.
Performance improvements
The new feature with the adapter in each binary test folder, will make the adapter loading faster. How much faster will depend on how many tests you have, and how many you select to run. It is expected to have most effect when you have many tests but just execute a few. Time will tell :-)
But I am not ready to do this Don’t worry! Deprecation don’t mean “not supported”. There will be a fallback option in Visual Studio which will start out by being enabled by default, and it will then use the old mechanism to search for and load adapters.
[caption id=“attachment_160544” align=“alignnone” width=“1403”] Suggested options dialog for handling test adapters[/caption]
In the first versions the full feature will be Opt In, although if you have the adapters correctly placed you will get the benefit. At some time later, it will be changed to Opt Out. (No time frame about when that change will happen has been published) The suggested options dialog is shown below (from ref.1 below):
At first, both (1) and (2) will be checked.
Checkbox (1) enables feature. If a test adapter is found in the given location, it will be used, and there will be no further search.
Checkbox (2) enables the fallback option. With this unchecked the test will not be run if there is no test adapter.
Note: The full precedence of the VSIX will not happen when you have these options enabled. The options as shown above will cause the test system to choose the optimal adapter where found.
When will this change appear
This feature will probably start to appear in the 15.8 update to VS2017, and can be seen in (currently upcoming per July 7th 2018) Preview 4. This should not adversely affect any existing projects, but will allow you to take advantage of it simply by having nuget test adapters in all test projects. The defaults will be set so that everything will continue to work as they do today.
Keep track here:
What about the command line There will be new command line options to control the behavior, see Ref.2 for details. Since build servers works by using the command line, either directly or through the VSTS/TFS test task, the latter will need to change to adopt the new behavior, it will only be a question of time before the default is changing here too. Since there will be a version update of the VSTest task to enable this, using the older version should keep you “safe” if you have VSIX adapters installed on all your build servers.
References
1.NUnit3 Test Adapter issue raised by MS 2.Documentation for the new test behaviour 3.Release note comment for the feature for VS 2017 Update 15.8 Preview 4