Windows Protocol Test Suites provide interoperability testing against the implementation of Windows open specifications including File Services, Identity Management, Remote Desktop and etc.
Originally developed for in-house testing of the Microsoft Open Specifications, Microsoft Protocol Test Suites have been used extensively during Plugfests and interoperability labs to test against partner implementations. A Test Suite evaluates whether a protocol or protocol family implementation meets certain interoperability requirements. Test Suites do not cover every protocol requirement and in no way certify an implementation, even if all tests pass. However, each test suite provides users with a useful indication of interoperability.
- File Server Family Test Suite. It is designed to test implementations of file server protocol family including [MS-SMB2], [MS-DFSC], [MS-SWN], [MS-FSRVP], [MS-FSA], [MS-FSCC], [MS-RSVD] and [MS-SQOS].
- RDP Client Family Test Suite. It provides interoperability testing for client implementation of RDP family protocols including [MS-RDPBCGR], [MS-RDPEDISP], [MS-RDPEDYC], [MS-RDPEGFX], [MS-RDPEGT], [MS-RDPEI], [MS-RDPEMT], [MS-RDPEUDP], [MS-RDPEUSB], [MS-RDPEVOR] and [MS-RDPRFX].
- RDP Server Family Test Suite. It provides interoperability testing for server implementation of RDP family protocols including [MS-RDPBCGR], [MS-RDPEDYC], [MS-RDPEMT] and [MS-RDPELE].
- Kerberos Server Test Suite. It is designed to test server implementations of Kerberos protocols including [MS-KILE], [MS-KKDCP] and [MS-PAC].
- SMBD Server Test Suite. It is designed to test the implementations of SMB2&3 direct (RDMA) protocol, as specified in [MS-SMBD] and [MS-SMB2].
- Branch Cache Test Suite. It is designed to test the implementations of [MS-PCCRTP], [MS-PCCRR], [MS-PCHC] and [MS-PCCRC] protocol.
- AZOD Test Suite. It is designed to test the implementations of [MS-AZOD] protocol.
- ADFamily Test Suite. It is designed to test the implementations of the Active Directory protocols including [MS-ADA1], [MS-ADA2], [MS-ADA3], [MS-ADLS], [MS-ADSC], [MS-ADTS], [MS-APDS], [MS-DRSR], [MS-FRS2], [MS-LSAD], [MS-LSAT], [MS-SAMR] and [MS-NRPC].
- ADFSPIP Client Test Suite. It is designed to test the implementations of ADFS Proxy and Web Application Proxy integration, as described in [MS-ADFSPIP].
- ADOD Test Suite. It is designed to test the implementations of [MS-ADOD] protocol.
Windows Protocol Test Suites contain below components:
- CommonScripts. Common scripts used by each test suite. Normally they're used to deploy the environment.
- ProtoSDK. The protocol library used by each test suite. It provides the data structures of the protocol messages, the methods to encode and decode the messages, the methods to send and receive messages and etc.
- TestSuites. All Test Suites code and documents are saved here and categorized by folder representing each test suite.
- ProtocolTestManager. A tool to help you configure and run test suites.
Windows Protocol Test Suites are based on .NET so they can be developed and run across different platforms. You should install the software listed below based on your testing purpose, including their own dependencies.
- 
.NET and related components a. For Windows, Linux and macOS, install .NET 6.0 SDK to build or run test suites. b. For those who work on Windows and prefer IDE, install Visual Studio 2022 or higher (Visual Studio 2022 Community recommended), together with these individual components from the installer: Section Individual Component in Visual Studio 2022 Run Windows Protocol Test Suites Build Windows Protocol Test Suites from source code .NET .NET SDK Required Required Compilers, build tools, and runtime C# and Visual Basic Roslyn compilers Required Compilers, build tools, and runtime MSVC v143 - VS 2022 C++ x64/x86 build tools (Latest) Required1 Compilers, build tools, and runtime C++/CLI support for v143 build tools (Latest) Required1 Compilers, build tools, and runtime C++ 2022 Redistributable Update Required1 Required1 Development Activities C++ core features Required1 SDKs, libraries, and frameworks Windows 10 SDK (10.0.19041.0) Required1 Note: 
[1]: This individual component is required by ADFamily and MS-SMBD which have C++ code.
- 
Protocol Test Framework v2.3 (build 2.3.0) Protocol Test Framework is referenced by projects of ProtoSDK and TestSuites as NuGet packages. 
- 
From NetworkDirect_DDK.zipextractndspi.handndstatus.hinto project pathProtoSDK\RDMA\include. This is to build SMBD test suite.
- 
This is required only when user want to use PowerShell Core Remoting over SSH. 
- 
This is required only when user want to use PowerShell Core Remoting over SSH for Windows platform. 
- 
This is required only when user want to use PowerShell implementation on Windows Server 2012R2 for ISutCommonControlAdapter in CommonTestSuite.ptfconfig. a. If you choose PowerShell implementation for ISutCommonControlAdapter in a domain environment where the DC runs Windows Server 2012R2, in order to get SID from the DC, you need to install WMF 5.1 on the DC, for other Windows Server versions newer than Windows Server 2012R2, you do not need to install WMF 5.1 on the DC. b. If you choose PowerShell implementation for ISutCommonControlAdapter on Windows platforms (including Windows Server 2012R2 and newer versions) in workgroup environment, you do not need to install WMF 5.1 on the SUT. c. If you choose managed implementation for ISutCommonControlAdapter on Windows platforms (including Windows Server 2012R2 and newer versions), it will use LDAP queries to get SID and only supports domain environment. 
If your work on Windows, you can use the script in InstallPrerequisites folder to automatically download and install these software.
Tips when using the script in InstallPrerequisites folder:
- To run the script, open Windows PowerShell, and execute the commands below in the PowerShell Window:
cd WindowsProtocolTestSuites\InstallPrerequisites
.\InstallPrerequisites.ps1
- If you meet errors about Execution Policy, make sure you run Windows PowerShell as Administrator, and type the following and enter:
Set-ExecutionPolicy RemoteSigned
You could run the command below to verify if the Execution Policy is correctly set:
Get-ExecutionPolicy
Then rerun the script.
After you clone a copy of this repo, you can run build.ps1 in PowerShell or build.sh in shell for each test suite separately after you have installed all the softwares required for build listed in Prerequisites.
For example, if you want to build FileServer test suite:
cd WindowsProtocolTestSuites\TestSuites\FileServer\src
build.ps1
After the build succeeds, the common folder structure should be generated in the folder WindowsProtocolTestSuite\drop\TestSuites\[TestSuiteName]\.
- Bin: all the built binaries including ProtoSDK, adapters and test suites.
- Batch: batch files (.ps1, .sh) which can be used to launch tests.
- Scripts: scripts which can be used to configure test environment.
- Utils: some utilities which can be used in tests.
Before running a test suite, you need do either of below:
- Download the test suite archive you want to run from Releases, and extract it to some path you have access.
- Build the test suite according to Build a test suite.
On macOS, the FileServer test suite uses AesCcm and AesGcm classes which require OpenSSL, so if there is not OpenSSL 1.1 on your macOS please install OpenSSL 1.1 and set the environment variable as following before you run the FileServer test suite on macOS,
brew install openssl@1.1
export DYLD_LIBRARY_PATH="/usr/local/opt/openssl@1.1/lib:$DYLD_LIBRARY_PATH"
Note:
- If brewis not installed on your macOS, you can install it according to brew.
- If you get the error "algorithm 'aesgcm' is not supported on this platform", that means dotnet cannot load AesGcm class from libcrypto.1.1.dylib on your macOS, then you need to check whether its location is in your DYLD_LIBRARY_PATHenvironment variable or not. Once you install OpenSSL 1.1 on your macOS the crypto library location is/usr/local/Cellar/openssl@1.1/1.1.1m/lib/libcrypto.1.1.dyliband/usr/local/opt/openssllinks to the/usr/local/Cellar/openssl@1.1/1.1.1mdirectory by default.
In the Batch folder under root path of the test suite, there are several scripts you can use to launch tests.
- 
Run all test cases Execute RunAllTestCases.ps1in PowerShell, orRunAllTestCases.shin shell directly.
- 
Run test cases by filters Execute RunTestCasesByFilter.ps1 -Filter [your filter expression]in PowerShell, orRunTestCasesByFilter.sh [your filter expression]in shell directly.For example, you can run below command if you want to run test cases with test category BVTandSMB311:RunTestCasesByFilter.sh "TestCategory=BVT&TestCategory=SMB311"For more information about how to construct the filter expression, you can refer to Filter option details. 
- 
Dry run If you want to list the test cases before running them actually, you could add -DryRunswitch to.ps1scripts or pass a non-empty string as the last argument to.shscripts.For example, you can run below command if you want to list test cases with test category BVTandSMB311:RunTestCasesByFilter.sh "TestCategory=BVT&TestCategory=SMB311" "list"
Take File Server test suite as an example, you can learn how to configure and run test suite by Protocol Test Manager referring to this tutorial.
You could set up the test environment and configure the test suite according to its User Guide.
Each test suite has its own User Guide in the WindowsProtocolTestSuites\TestSuites\[TestSuiteName]\docs folder.
There are two more kinds of documents in the same folder:
- Technical Documents. The Open Specifications documentation for protocols, published by Microsoft. It's the basis of developing Test Suites.
- Test Design Specs. It provides information about the test scope and test suite design.
You can find contributing guide here.
Windows Protocol Test Suites are under the MIT license.
The following resources are for Windows protocol test suite news, discussion, and support:
- View news announcements in Open Specification Windows Protocols Forum.
- Discuss test suites issues here on the github.
- For Open Specifications Protocols support, contact dochelp@microsoft.com.
This project has adopted the Microsoft Open Source Code of Conduct. For more information see the Code of Conduct FAQ or contact opencode@microsoft.com with any additional questions or comments.