MSTEST0008. Метод TestInitialize должен иметь допустимый макет
Свойство | Значение |
---|---|
Идентификатор правила | MSTEST0008 |
Заголовок | Метод TestInitialize должен иметь допустимый макет |
Категория | Использование |
Исправление является критическим или не критическим | Не критическое |
Включен по умолчанию | Да |
Серьезность по умолчанию | Предупреждение |
Представлено в версии | 3.3.0 |
Есть ли исправление кода? | Да |
Причина
Метод, помеченный как [TestInitialize]
допустимый макет.
Описание правила
Методы, помеченные как допустимые, [TestInitialize]
должны соответствовать следующему макету:
- оно должно быть
public
- это не должно быть
abstract
- это не должно быть
async void
- это не должно быть
static
- он не должен быть специальным методом (метод завершения, оператор...).
- Оно не должно быть универсальным
- Он не должен принимать какой-либо параметр
- Тип возвращаемого значения должен иметь значение
void
Task
или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
Дополнительные сведения см. в статье Подавление предупреждений анализа кода.