Not
Bu sayfaya erişim yetkilendirme gerektiriyor. Oturum açmayı veya dizinleri değiştirmeyi deneyebilirsiniz.
Bu sayfaya erişim yetkilendirme gerektiriyor. Dizinleri değiştirmeyi deneyebilirsiniz.
Bu makale, MSTest.Sdk için gelişmiş yapılandırma seçeneklerini kapsar. Temel kurulum ve başlangıç için bkz. MSTest ile Başlarken.
Önemli
Varsayılan olarak MSTest.Sdk, dotnet testi de dahil olmak üzere MTP ile MSTest çalıştırıcısını kullanır. Bunun için CI ve yerel CLI çağrılarınızın değiştirilmesi gerekir ve . runsettings'in kullanılabilir girdilerini de etkiler. VSTest'e geçerek eski tümleştirmeleri ve araçları koruyabilirsiniz.
MSTest.Sdk varsayılan olarak EnableMSTestRunner ve TestingPlatformDotnetTestSupport değerlerini true olarak ayarlar. dotnet testi ve farklı modları hakkında daha fazla bilgi için dotnet testi kullanarak test etme bölümüne bakın.
Yardımcı araç kütüphanelerini test etme
MSTest.Sdk kullanan proje bir test yardımcı kitaplığı olması amaçlanıyor ve kendi başına çalıştırılabilir testler içermiyorsa, proje <IsTestApplication>false</IsTestApplication> olmalıdır.
Koşucuyu seçin
Varsayılan olarak, MSTest SDK'sı MTP'ye dayanır, ancak özelliğini ekleyerek <UseVSTest>true</UseVSTest> geçebilirsiniz.
MTP'nin kapsamını genişletme
Bir dizi NuGet paket uzantısı aracılığıyla MTP deneyimini özelleştirebilirsiniz. Bu deneyimi basitleştirmek ve geliştirmek için MSTest SDK'sı iki özellik sunar:
Microsoft.Testing.Platform profili
profiles kavramı, test project uygulanacak varsayılan yapılandırma ve uzantı kümesini seçmenize olanak tanır.
Özelliği TestingExtensionsProfile kullanarak aşağıdaki üç profilden birini seçip profili ayarlayabilirsiniz:
None- Hiçbir uzantı etkinleştirilmedi.Default- MSTest.SDK'nın bu sürümü için önerilen uzantıları etkinleştirir. Özellik açıkça ayarlı olmadığında bu varsayılan değerdir.Aşağıdaki uzantıları etkinleştirir:
AllMicrosoft- Microsoft (kısıtlayıcı lisansa sahip uzantılar dahil) tarafından gönderilen tüm uzantıları etkinleştirin.Aşağıdaki uzantıları etkinleştirir:
- Kod Kapsamı
- kilitlenme dökümü
- Fakes (MSTest.Sdk 3.7.0+)
- Askı Dökümü
- Anında Yeniden Yükleme
- Yeniden Dene
- Trx Raporu
- AzureDevOpsReport
İşte None profilinin kullanıldığı tam bir örnek:
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<TestingExtensionsProfile>None</TestingExtensionsProfile>
</PropertyGroup>
</Project>
| Eklenti/Profil | Hiç kimse | Varsayılan | AllMicrosoft |
|---|---|---|---|
| Kod Kapsamı | ✔️ | ✔️ | |
| kilitlenme dökümü | ✔️ | ||
| Fakes | ✔️¹ | ||
| Askı Dökümü | ✔️ | ||
| Anında Yeniden Yükleme | ✔️ | ||
| Yeniden Dene | ✔️ | ||
| Trx | ✔️ | ✔️ | |
| AzureDevOpsReport | ✔️² |
¹ MSTest.Sdk 3.7.0+ ² MSTest.Sdk 3.11.0+
Uzantıları etkinleştirme veya devre dışı bırakma
Uzantılar, deseni Enable[NugetPackageNameWithoutDots]ile MSBuild özellikleri tarafından etkinleştirilebilir ve devre dışı bırakılabilir.
Örneğin, kilitlenme dökümü uzantısını etkinleştirmek için (NuGet paketi Microsoft.Testing.Extensions.CrashDump), aşağıdaki EnableMicrosoftTestingExtensionsCrashDump değerini true olarak ayarlayabilirsiniz:
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<EnableMicrosoftTestingExtensionsCrashDump>true</EnableMicrosoftTestingExtensionsCrashDump>
</PropertyGroup>
</Project>
Kullanılabilir tüm uzantıların listesi için bkz. MTP özellikleri.
Uyarı
Farklılık gösterebileceğinden her uzantının lisans koşullarını gözden geçirmek önemlidir.
Etkin ve devre dışı bırakılmış uzantılar, seçtiğiniz uzantı profili tarafından sağlanan uzantılarla birleştirilir.
Örtük Default profilinin üzerinde ek bir uzantı etkinleştirmek için bu özellik deseni kullanılabilir (önceki CrashDumpExtension örneğinde görüldüğü gibi).
Seçili profilden gelen bir uzantıyı da devre dışı bırakabilirsiniz. Örneğin, MS Code Coverage uzantısını devre dışı bırakmak için <EnableMicrosoftTestingExtensionsCodeCoverage>false</EnableMicrosoftTestingExtensionsCodeCoverage> ayarını yapın.
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<EnableMicrosoftTestingExtensionsCodeCoverage>false</EnableMicrosoftTestingExtensionsCodeCoverage>
</PropertyGroup>
</Project>
Özellikler
Seçilen koşucu ve koşucuya özgü uzantıların ötesinde, MSTest.Sdk test deneyiminizi basitleştirmek ve geliştirmek için ek özellikler de sunar.
Test edin ile
Aspire gözlemlenebilir, üretime hazır, dağıtılmış uygulamalar oluşturmaya yönelik, fikir temelli, buluta hazır bir yığındır. Aspire, belirli buluta özgü sorunları ele almak için bir NuGet paketi koleksiyonu aracılığıyla sağlanır. Daha fazla bilgi için belgelereAspire bakın.
Uyarı
Bu özellik MSTest.Sdk 3.4.0'dan kullanılabilir.
Özelliği EnableAspireTesting olarak true ayarlayarak, using ve Aspire ile test etmek için ihtiyacınız olan tüm bağımlılıkları ve varsayılan MSTest yönergelerini getirebilirsiniz.
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<EnableAspireTesting>true</EnableAspireTesting>
</PropertyGroup>
</Project>
Playwright ile test et
Playwright, modern web apps için güvenilir uçtan uca test olanağı sağlar. Daha fazla bilgi için resmi Playwright belgelerine bakın.
Uyarı
Bu özellik MSTest.Sdk 3.4.0'dan kullanılabilir.
Özelliği EnablePlaywright olarak ayarlayarak, true ile using için gerekli olan tüm bağımlılıkları ve varsayılan Playwright yönergelerini MSTest ile test etmek amacıyla ekleyebilirsiniz.
<Project Sdk="MSTest.Sdk/4.1.0">
<PropertyGroup>
<TargetFramework>net10.0</TargetFramework>
<EnablePlaywright>true</EnablePlaywright>
</PropertyGroup>
</Project>
MSTest SDK'sına geçiş
MSTest SDK'sına geçiş yapmak için gereken aşağıdaki adımları göz önünde bulundurun.
Projenizi güncelleyin
Mevcut bir MSTest test projesini MSTest SDK'sına geçirirken, test projenizin üst kısmındaki Sdk="Microsoft.NET.Sdk" girişini Sdk="MSTest.Sdk" ile değiştirerek başlayın
- Sdk="Microsoft.NET.Sdk"
+ Sdk="MSTest.Sdk"
global.json sürümünüze ekleyin:
{
"msbuild-sdks": {
"MSTest.Sdk": "4.1.0"
}
}
Daha sonra project basitleştirmeye başlayabilirsiniz.
Varsayılan özellikleri kaldır:
- <EnableMSTestRunner>true</EnableMSTestRunner>
- <OutputType>Exe</OutputType>
- <IsPackable>false</IsPackable>
- <IsTestProject>true</IsTestProject>
Varsayılan paket atıflarını kaldır.
- <PackageReference Include="MSTest"
- <PackageReference Include="MSTest.TestFramework"
- <PackageReference Include="MSTest.TestAdapter"
- <PackageReference Include="MSTest.Analyzers"
- <PackageReference Include="Microsoft.NET.Test.Sdk"
Son olarak, kullandığınız uzantı profiline bağlı olarak, Microsoft.Testing.Extensions.* paketlerinden bazılarını da kaldırabilirsiniz.
CI'nizi güncelleştirme
Projelerinizi güncelleştirdikten sonra, MTP (varsayılan) kullanıyorsanız ve testlerinizi çalıştırmaya güveniyorsanız dotnet test CI yapılandırmanızı güncelleştirmeniz gerekir. Daha fazla bilgi edinmek ve gerekli tüm değişiklikleri anlamanızı sağlamak için bkz: dotnet test tümleştirmesi.
dotnet test VSTest modunu kullanıyorsanız, Azure DevOps'da DotNetCoreCLI görevi kullanılırken örnek bir güncelleştirme aşağıda verilmiştir:
\- task: DotNetCoreCLI@2
inputs:
command: 'test'
projects: '**/**.sln'
- arguments: '--configuration Release'
+ arguments: '--configuration Release -- --report-trx --results-directory $(Agent.TempDirectory) --coverage'
Bilinen sınırlamalar
NuGet tarafından sağlanan MSBuild SDK'ları (MSTest.Sdk dahil), sürümlerini güncelleştirme konusunda sınırlı araç desteğine sahiptir; bu da NuGet paketlerini yönetmek için sunulan normal NuGet güncellemesinin ve Visual Studio kullanıcı arabiriminin beklendiği gibi çalışmaması anlamına gelir. sürümü global.json dosyasında ve project dosyasında el ile güncelleştirmeniz gerekir. (dependabot-core#12824 ve dependabot-core#8615 sorunları nedeniyle Dependabot kullanıyor olsanız bile bu durum geçerlidir.)