diff --git a/docs/core/testing/mstest-analyzers/mstest0037.md b/docs/core/testing/mstest-analyzers/mstest0037.md new file mode 100644 index 0000000000000..0a93f85b6b712 --- /dev/null +++ b/docs/core/testing/mstest-analyzers/mstest0037.md @@ -0,0 +1,59 @@ +--- +title: "Use proper 'Assert' methods" +description: "Learn about code analysis rule MSTEST0037: Use proper 'Assert' methods." +ms.date: 11/17/2024 +f1_keywords: +- MSTEST0037 +- UseProperAssertMethodsAnalyzer +helpviewer_keywords: +- UseProperAssertMethodsAnalyzer +- MSTEST0037 +author: Youssef1313 +ms.author: ygerges +--- +# MSTEST0037: Use proper 'Assert' methods + +| Property | Value | +|-------------------------------------|------------------------------------------------------------------------| +| **Rule ID** | MSTEST0037 | +| **Title** | Use proper 'Assert' methods | +| **Category** | Usage | +| **Fix is breaking or non-breaking** | Non-breaking | +| **Enabled by default** | Yes | +| **Default severity** | Info | +| **Introduced in version** | 3.7.0 | +| **There is a code fix** | No | + +## Cause + +The use of methods in a specific way when there is a better alternative. + +## Rule description + +There are multiple cases where you get this warning: + +- The use of `Assert.IsTrue( == null)` (with all combinations, like `IsFalse`, `!= null`, `is null`, or `is not null`). + + Using `Assert.IsNull()` or `Assert.IsNotNull()` is a better alternative. + +- The use of `Assert.IsTrue( == )` (with all combinations, like `IsFalse` or `!=`). + + Using `Assert.AreEqual(, )` or `Assert.AreNotEqual(, )` is a better alternative. + +- The use of `Assert.AreEqual(true, )` or `Assert.AreEqual(false, )`. + + Using `Assert.IsTrue()` or `Assert.IsFalse()` is a better alternative. + +- The use of `Assert.AreEqual(null, )` or `Assert.AreNotEqual(null, )`. + + Using `Assert.IsNull()` or `Assert.IsNotNull` is a better alternative. + +In many cases, the better alternatives provide better messages when they fail and are also easier to read. + +## How to fix violations + +Use the better alternative method. + +## When to suppress warnings + +You usually don't want to suppress warnings from this rule. diff --git a/docs/core/testing/mstest-analyzers/usage-rules.md b/docs/core/testing/mstest-analyzers/usage-rules.md index 6d2777c2cc68b..c8a742fc973af 100644 --- a/docs/core/testing/mstest-analyzers/usage-rules.md +++ b/docs/core/testing/mstest-analyzers/usage-rules.md @@ -27,3 +27,4 @@ Identifier | Name | Description [MSTEST0023](mstest0023.md) | DoNotNegateBooleanAssertionAnalyzer | Do not negate boolean assertions [MSTEST0024](mstest0024.md) | DoNotStoreStaticTestContextAnalyzer | Do not store TestContext in a static member [MSTEST0026](mstest0026.md) | AssertionArgsShouldAvoidConditionalAccessRuleId | Avoid conditional access in assertions +[MSTEST0037](mstest0037.md) | UseProperAssertMethodsAnalyzer | Use proper `Assert` methods diff --git a/docs/navigate/devops-testing/toc.yml b/docs/navigate/devops-testing/toc.yml index 4ee918edae68e..18712a198c48f 100644 --- a/docs/navigate/devops-testing/toc.yml +++ b/docs/navigate/devops-testing/toc.yml @@ -187,6 +187,8 @@ items: href: ../../core/testing/mstest-analyzers/mstest0034.md - name: MSTEST0035 href: ../../core/testing/mstest-analyzers/mstest0035.md + - name: MSTEST0037 + href: ../../core/testing/mstest-analyzers/mstest0037.md - name: Microsoft Testing Platform items: - name: Overview