Skip to content

Latest commit

 

History

History
90 lines (68 loc) · 3.33 KB

testing.md

File metadata and controls

90 lines (68 loc) · 3.33 KB

Testing Libraries

We use the OSS testing framework xunit.

To build the tests and run them you can call the libraries build script. For libraries tests to work, you must have built the coreclr or mono runtime for them to run on.

Examples

  • The following shows how to build only the tests but not run them:
build.cmd/sh -subset libs.tests
  • The following builds and runs all tests using clr:
build.cmd/sh -subset clr+libs.tests -test
  • The following builds and runs all tests using mono:
build.cmd/sh -subset mono+libs.tests -test
  • The following builds and runs all tests in release configuration:
build.cmd/sh -subset libs.tests -test -c Release
  • The following builds clr in release, libs in debug and runs all tests:
build.cmd/sh -subset clr+libs+libs.tests -test -rc Release
  • The following builds mono and libs for x86 architecture and runs all tests:
build.cmd/sh -subset mono+libs+libs.tests -test -arch x86
  • The following example shows how to pass extra msbuild properties to ignore tests ignored in CI:
build.cmd/sh -subset libs.tests -test /p:WithoutCategories=IgnoreForCI

Unless you specifiy -testnobuild, test assemblies are implicitly built when invoking the Test action.

  • The following shows how to only test the libraries without building them
build.cmd/sh -subset libs.tests -test -testnobuild

Running tests on the command line

To build tests you need to specify the test subset when invoking build.cmd/sh: build.cmd/sh -subset libs.tests.

The easiest (and recommended) way to build and run the tests for a specific library, is to invoke the Test target on that library:

cd src\libraries\System.Collections.Immutable\tests
dotnet build /t:Test

It is possible to pass parameters to the underlying xunit runner via the XUnitOptions parameter, e.g.:

dotnet build /t:Test /p:XUnitOptions="-class Test.ClassUnderTests"

Which is very useful when you want to run tests as x86 on a x64 machine:

dotnet build /t:Test /p:TargetArchitecture=x86

There may be multiple projects in some directories so you may need to specify the path to a specific test project to get it to build and run the tests.

Running a single test on the command line

To quickly run or debug a single test from the command line, set the XunitMethodName property, e.g.:

dotnet build /t:Test /p:XunitMethodName={FullyQualifiedNamespace}.{ClassName}.{MethodName}

Running outer loop tests

To run all tests, including "outer loop" tests (which are typically slower and in some test suites less reliable, but which are more comprehensive):

dotnet build /t:Test /p:Outerloop=true

Running tests on a different target framework

Each test project can potentially have multiple target frameworks. There are some tests that might be OS-specific, or might be testing an API that is available only on some target frameworks, so the TargetFrameworks property specifies the valid target frameworks. By default we will build and run only the default build target framework which is net5.0. The rest of the TargetFrameworks will need to be built and ran by specifying the BuildTargetFramework option, e.g.:

dotnet build src\libraries\System.Runtime\tests\System.Runtime.Tests.csproj /p:BuildTargetFramework=net472