0b36151638
Switch APIScan to use a managed identity |
||
---|---|---|
.config | ||
.devcontainer | ||
.github | ||
.vscode | ||
azure-pipelines | ||
src | ||
test | ||
tools | ||
.editorconfig | ||
.gitattributes | ||
.gitignore | ||
CODE_OF_CONDUCT.md | ||
CONTRIBUTING.md | ||
Directory.Build.props | ||
Directory.Build.rsp | ||
Directory.Build.targets | ||
ExtensionTesting.sln | ||
LICENSE | ||
NuGet.config | ||
README.md | ||
SECURITY.md | ||
SUPPORT.md | ||
THIRD-PARTY-NOTICES.TXT | ||
azure-pipelines.yml | ||
global.json | ||
init.cmd | ||
init.ps1 | ||
stylecop.json | ||
version.json |
README.md
Visual Studio Extension Testing
This project allows Visual Studio extension developers to write integration tests that run inside an experimental instance of Visual Studio.
Installation and Use
Requirements
- Extension development requires Visual Studio 2017 or newer. Version 15.7 or newer is recommended for the best Test Explorer experience.
- Extensions themselves must target one or more versions of Visual Studio from the following list:
- Visual Studio 2012
- Visual Studio 2013
- Visual Studio 2015
- Visual Studio 2017
- Visual Studio 2019
- Visual Studio 2022
- Extensions must be deployed via one or more VSIX packages.
- Test execution and debugging is only supported for versions of Visual Studio available on the same machine as the development IDE.
Install the test harness
Install the test package for the applicable version(s) of Visual Studio
Visual Studio Version | Integration Testing Package |
---|---|
2022 | Microsoft.VisualStudio.Extensibility.Testing.Xunit |
2012 - 2019 | Microsoft.VisualStudio.Extensibility.Testing.Xunit.Legacy |
Configure the test framework
Classic projects
Add the following to AssemblyInfo.cs to enable the test framework:
using Xunit;
[assembly: TestFramework("Xunit.Harness.IdeTestFramework", "Microsoft.VisualStudio.Extensibility.Testing.Xunit")]
SDK projects
💡 By default, SDK projects automatically generate the required assembly attribute. Manual customization is only required if the default assembly attributes support has been disabled, or in cases where the automatic application of
TestFrameworkAttribute
is not desired.
To disable generation of TestFrameworkAttribute
(which will require manual addition similar to classic projects), add
the following to the project file:
<PropertyGroup>
<GenerateTestFrameworkAttribute>false</GenerateTestFrameworkAttribute>
</PropertyGroup>
Configure extensions for deployment
Add the following to AssemblyInfo.cs to deploy extensions required for testing.
using Xunit.Harness;
[assembly: RequireExtension("Extension.File.Name.vsix")]
Ensure test discovery is enabled
Test projects using a customized xUnit test framework cannot currently be discovered while tests are being written. The test discovery process that runs after a build completes will detect the required tests. Ensure this feature is enabled by the following steps:
- Open Tools → Options...
- Select the Test page on the left
- Ensure Additionally discover tests from built assemblies after builds is checked
Tests will be automatically discovered and Test Explorer updated after each successful build.
Write tests
Apply the [IdeFact]
attribute to tests that need to run in the IDE. After building the project, the tests will
appear in Test Explorer where they can be launched for running and/or debugging directly.
Contributing
Please see CONTRIBUTING.md for information about our Code of Conduct and contributing guidelines.