Поделиться через


MSTEST0008. Метод TestInitialize должен иметь допустимый макет

Свойство Значение
Идентификатор правила MSTEST0008
Заголовок Метод TestInitialize должен иметь допустимый макет
Категория Использование
Исправление является критическим или не критическим Не критическое
Включен по умолчанию Да
Серьезность по умолчанию Предупреждение
Представлено в версии 3.3.0
Есть ли исправление кода? Да

Причина

Метод, помеченный как [TestInitialize] допустимый макет.

Описание правила

Методы, помеченные как допустимые, [TestInitialize] должны соответствовать следующему макету:

  • оно должно быть public
  • это не должно быть abstract
  • это не должно быть async void
  • это не должно быть static
  • он не должен быть специальным методом (метод завершения, оператор...).
  • Оно не должно быть универсальным
  • Он не должен принимать какой-либо параметр
  • Тип возвращаемого значения должен иметь значение voidTask илиValueTask

Тип, объявляющий эти методы, также должен соблюдать следующие правила:

  • Тип должен быть class.
  • Должен class быть public или internal (если тестовый проект использует [DiscoverInternals] атрибут).
  • Не class должно быть static.
  • Если значение class имеет значение sealed, оно должно быть отмечено производным [TestClass] атрибутом (или производным атрибутом).

Устранение нарушений

Убедитесь, что метод соответствует приведенному выше макету.

Когда лучше отключить предупреждения

Для этого правила отключать вывод предупреждений не следует. Если игнорировать это правило, помеченные экземпляры будут пропущены или приводят к ошибке среды выполнения.

Подавление предупреждения

Если вы просто хотите отключить одно нарушение, добавьте директивы препроцессора в исходный файл, чтобы отключить и повторно включить правило.

#pragma warning disable MSTEST0008
// The code that's violating the rule is on this line.
#pragma warning restore MSTEST0008

Чтобы отключить правило для файла, папки или проекта, задайте его серьезность в файле конфигурации.

[*.{cs,vb}]
dotnet_diagnostic.MSTEST0008.severity = none

Дополнительные сведения см. в статье Подавление предупреждений анализа кода.